:root{--bg: #fbfaf6;--surface: #ffffff;--surface-2: #f5f3ec;--surface-3: #ebe7da;--border: #e2ddcd;--border-strong: #cec7b2;--text: #14201a;--text-strong: #050a07;--text-muted: #5a6a5f;--text-subtle: #8e988e;--brand: #1f5f4a;--brand-deep: #163f31;--brand-darker: #0c2820;--brand-tint: #ebf3ef;--brand-tint-2: #d6e7dd;--brand-glow: rgba(31, 95, 74, .22);--brand-glow-soft: rgba(31, 95, 74, .08);--accent: #b88a3e;--accent-deep: #946d2c;--accent-darker: #6b4f1d;--accent-tint: #f8eed9;--accent-tint-2: #f1dfae;--accent-glow: rgba(184, 138, 62, .22);--accent-glow-soft: rgba(184, 138, 62, .1);--success: #0f9d58;--success-deep: #087443;--success-tint: #e6f6ee;--success-glow: rgba(15, 157, 88, .18);--danger: #c5333a;--danger-deep: #91232a;--danger-tint: #fbe7e7;--danger-glow: rgba(197, 51, 58, .18);--warning: #b46900;--warning-deep: #875000;--warning-tint: #fbeed7;--font-sans: "Geist", "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Geist Mono", "JetBrains Mono", ui-monospace, monospace;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--ease: cubic-bezier(.2, .7, .2, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#root{position:relative;isolation:isolate}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 900px 600px at 50% -10%,rgba(31,95,74,.1),transparent 65%),radial-gradient(ellipse 500px 350px at 90% 5%,rgba(184,138,62,.07),transparent 70%);pointer-events:none;z-index:-1}body:after{content:"";position:fixed;inset:0;background-image:radial-gradient(circle 1px at 1px 1px,rgba(20,32,26,.045) 1px,transparent 0);background-size:24px 24px;pointer-events:none;z-index:-1;mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,black 50%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,black 50%,transparent 100%)}button{font:inherit;letter-spacing:-.005em}.input{appearance:none;-webkit-appearance:none;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:.85rem 1rem;font-family:var(--font-sans);font-size:1rem;font-weight:500;color:var(--text-strong);width:100%;outline:none;letter-spacing:-.005em;transition:border-color .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease)}.input::placeholder{color:var(--text-subtle);font-weight:400}.input:hover:not(:disabled):not([disabled]){border-color:var(--border-strong)}.input:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-glow-soft)}.input:disabled,.input[disabled]{color:var(--text-subtle);cursor:not-allowed;background:var(--surface-2)}.input-textarea{resize:vertical;min-height:80px;line-height:1.55}.input-number{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:500}.input-affix{display:flex;align-items:stretch;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);overflow:hidden;transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}.input-affix:focus-within{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-glow-soft)}.input-affix:hover:not(:focus-within){border-color:var(--border-strong)}.input-affix .input{border:none;border-radius:0;box-shadow:none}.input-affix .input:focus{box-shadow:none}.input-prefix,.input-suffix{display:flex;align-items:center;padding:0 var(--space-3);background:var(--surface-2);color:var(--text-muted);font-family:var(--font-mono);font-size:.85rem}.input-enum-wrapper{display:flex;flex-direction:column;width:100%}.input-select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='9'><path d='M1 1l6 6 6-6' stroke='%231f5f4a' fill='none' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.75rem;cursor:pointer}.input-select:disabled{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='9'><path d='M1 1l6 6 6-6' stroke='%238e988e' fill='none' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'/></svg>")}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;padding:0 var(--space-5);border:1px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--text-strong);font-family:var(--font-sans);font-size:.95rem;font-weight:600;letter-spacing:-.005em;cursor:pointer;transition:background .18s var(--ease),color .18s var(--ease),border-color .18s var(--ease),box-shadow .18s var(--ease),transform .12s var(--ease)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff;box-shadow:inset 0 1px #ffffff2e,0 6px 18px -8px var(--brand-glow),0 1px 2px #0b12200f}.btn-primary:hover:not(:disabled){background:var(--brand-deep);transform:translateY(-1px);box-shadow:inset 0 1px #fff3,0 12px 28px -12px var(--brand-glow),0 2px 4px #0b12201a}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--text-strong)}.btn-secondary:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-strong)}.btn-link{padding:0;min-height:auto;background:transparent;color:var(--brand);text-decoration:none;border:none;font-weight:600;font-size:.92rem}.btn-link:hover:not(:disabled){color:var(--brand-deep);text-decoration:underline;text-underline-offset:3px}.login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;gap:1.25rem;text-align:center;animation:slideUp .5s var(--ease) backwards}.login-logo{max-width:220px;height:auto;margin-bottom:.5rem}.login-title{margin:0;font-family:var(--font-sans);font-size:clamp(2rem,6vw,2.75rem);font-weight:700;letter-spacing:-.03em;line-height:1;color:var(--text-strong)}.login-tagline{margin:0;color:var(--text-muted);font-size:1rem;max-width:360px}.login-button{margin-top:1rem;min-height:52px;padding:0 2rem;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:1rem;font-weight:600;letter-spacing:-.005em;cursor:pointer;display:inline-flex;align-items:center;gap:.6rem;box-shadow:inset 0 1px #fff3,0 8px 24px -10px var(--brand-glow),0 1px 2px #0b12200f;transition:background .2s var(--ease),transform .15s var(--ease),box-shadow .2s var(--ease)}.login-button:after{content:"→";font-family:var(--font-mono);font-weight:400;transition:transform .2s var(--ease)}.login-button:hover:not(:disabled){background:var(--brand-deep);transform:translateY(-1px);box-shadow:inset 0 1px #fff3,0 14px 32px -12px var(--brand-glow),0 2px 4px #0b122014}.login-button:hover:not(:disabled):after{transform:translate(3px)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-error{margin:0;color:var(--danger);background:var(--danger-tint);border:1px solid rgba(197,51,58,.2);border-radius:var(--radius-md);padding:.65rem 1rem;font-size:.9rem;font-weight:500}.shell{min-height:100vh;display:flex;flex-direction:column}.shell-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#ffffffd9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.shell-logo{height:32px;width:auto;align-self:center;flex-shrink:0}.shell-title{margin:0;font-size:1rem;font-weight:600;letter-spacing:-.015em;color:var(--text-strong);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shell-signout{padding:.45rem .9rem;background:transparent;border:1px solid var(--border);border-radius:999px;font-family:var(--font-sans);font-size:.85rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:color .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease)}.shell-signout:hover{color:var(--text-strong);border-color:var(--border-strong);background:var(--surface)}.shell-main{flex:1;padding:var(--space-4);max-width:1280px;width:100%;margin:0 auto}.tabbar{display:flex;gap:var(--space-2);overflow-x:auto;padding:var(--space-2) 0 var(--space-4);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabbar::-webkit-scrollbar{display:none}.tabbar-tab{flex-shrink:0;padding:.55rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-family:var(--font-sans);font-size:.88rem;font-weight:500;color:var(--text-muted);cursor:pointer;scroll-snap-align:start;white-space:nowrap;transition:background .18s var(--ease),color .18s var(--ease),border-color .18s var(--ease),box-shadow .18s var(--ease)}.tabbar-tab:hover{color:var(--text-strong);border-color:var(--border-strong)}.tabbar-tab-active,.tabbar-tab-active:hover{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 4px 14px -6px var(--brand-glow)}.data-toolbar{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.data-add{align-self:stretch}.data-add:before{content:"+";font-family:var(--font-mono);font-weight:500;font-size:1.1em;margin-right:.1rem}.data-loading,.data-empty{display:flex;align-items:center;justify-content:center;gap:.65rem;text-align:center;color:var(--text-muted);padding:3rem 1rem;font-size:.95rem;font-style:italic}.data-loading:before{content:"";width:14px;height:14px;border:2px solid var(--border-strong);border-top-color:var(--brand);border-radius:50%;animation:spin .75s linear infinite;flex-shrink:0}.filters{display:flex;flex-direction:column;gap:var(--space-2)}.filters-search{font-family:var(--font-sans)}.filters-select{cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='9'><path d='M1 1l6 6 6-6' stroke='%231f5f4a' fill='none' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.75rem}.filters-clear{align-self:flex-start;color:var(--text-muted);font-size:.85rem;font-weight:500;text-decoration:none}.filters-clear:hover:not(:disabled){color:var(--danger);text-decoration:underline;text-underline-offset:3px}.cardlist{display:flex;flex-direction:column;gap:var(--space-3)}.card{display:flex;flex-direction:column;gap:var(--space-2);padding:1.1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:left;cursor:pointer;position:relative;box-shadow:0 1px 2px #0b12200a,0 4px 12px -6px #0b12200a;transition:border-color .18s var(--ease),box-shadow .18s var(--ease),transform .12s var(--ease)}.card:hover{border-color:var(--brand-tint-2);transform:translateY(-1px);box-shadow:0 1px 2px #0b12200a,0 14px 28px -14px var(--brand-glow),0 0 0 1px var(--brand-glow-soft)}.card:active{transform:translateY(0)}.card:after{content:"→";position:absolute;top:1.1rem;right:1.1rem;color:var(--brand);font-family:var(--font-mono);font-size:.95rem;opacity:0;transition:opacity .18s var(--ease),transform .18s var(--ease)}.card:hover:after{opacity:1;transform:translate(2px)}.card-field{display:flex;flex-direction:column;align-items:stretch;gap:.2rem;min-width:0}.card-label{color:var(--text-muted);font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;white-space:normal;word-break:break-word}.card-value{font-weight:500;font-size:.95rem;color:var(--text-strong);font-variant-numeric:tabular-nums;white-space:normal;word-break:break-word}.card-field-currency .card-value,.card-field-percent .card-value,.card-field-decimal .card-value,.card-field-integer .card-value{font-family:var(--font-mono);font-weight:400}.card-field-textarea .card-value{font-weight:400;font-family:var(--font-sans);color:var(--text);white-space:pre-wrap}.datatable-wrapper{overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 1px 2px #0b12200a,0 4px 12px -6px #0b12200a}.datatable{width:100%;border-collapse:collapse;font-size:.92rem}.datatable th{background:var(--surface-2);font-family:var(--font-mono);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:.8rem 1rem;text-align:left;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1;white-space:nowrap}.datatable td{padding:.85rem 1rem;border-bottom:1px solid var(--border);white-space:nowrap;font-weight:500;color:var(--text-strong);font-variant-numeric:tabular-nums}.datatable tbody tr{transition:background .12s var(--ease)}.datatable tbody tr:hover{background:var(--surface-2)}.datatable tbody tr:last-child td{border-bottom:none}.datatable-actions{text-align:right;width:1%}.datatable-actions .btn-link{font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.datatable-actions .btn-link:after{content:" →";font-family:var(--font-mono)}.dialog-backdrop{position:fixed;inset:0;background:#14201a80;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:stretch;justify-content:center;z-index:100;animation:fadeIn .18s var(--ease)}.dialog{background:var(--surface);width:100%;height:100%;max-height:100dvh;border-radius:0;display:flex;flex-direction:column;box-shadow:0 -8px 32px #0b122029,0 -1px 4px #0b12200f;animation:dialogUp .25s var(--ease-bounce)}@keyframes dialogUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.dialog-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:1.1rem var(--space-5);border-bottom:1px solid var(--border);background:var(--surface)}.dialog-title{margin:0;font-size:1.1rem;font-weight:700;letter-spacing:-.015em;color:var(--text-strong)}.dialog-close{width:36px;height:36px;background:transparent;border:1px solid transparent;border-radius:50%;font-size:1.4rem;color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;transition:background .18s var(--ease),color .18s var(--ease),border-color .18s var(--ease)}.dialog-close:hover{background:var(--surface-2);color:var(--text-strong);border-color:var(--border)}.dialog-form{display:flex;flex-direction:column;flex:1;min-height:0}.dialog-fields{flex:1;overflow-y:auto;padding:1.25rem var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.dialog-field{display:flex;flex-direction:column;gap:.4rem}.dialog-label{font-family:var(--font-mono);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.dialog-label-hint{font-family:var(--font-mono);font-size:.65rem;font-weight:500;color:var(--accent);margin-left:.3rem;text-transform:none;letter-spacing:.02em;font-style:normal;opacity:1}.dialog-error{margin:0 var(--space-5);padding:.7rem .9rem;background:var(--danger-tint);border:1px solid rgba(197,51,58,.25);border-radius:var(--radius-sm);color:var(--danger-deep);font-size:.88rem;font-weight:500}.dialog-actions{display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-top:1px solid var(--border);background:var(--surface);position:sticky;bottom:0}.dialog-actions .btn{flex:1}.toast-stack{position:fixed;bottom:var(--space-4);left:var(--space-4);right:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);z-index:200;pointer-events:none}.toast{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:.85rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 1px 2px #0b12200a,0 18px 36px -16px #0b12202e;pointer-events:auto;font-size:.9rem;font-weight:500;animation:toastIn .25s var(--ease-bounce)}@keyframes toastIn{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.toast-success{border-left:3px solid var(--success);color:var(--text-strong)}.toast-error{border-left:3px solid var(--danger);color:var(--text-strong)}.toast-warning{border-left:3px solid var(--warning);color:var(--text-strong)}.toast-close{background:transparent;border:none;font-size:1.2rem;line-height:1;cursor:pointer;color:var(--text-subtle);padding:.25rem .5rem;margin:-.25rem -.4rem -.25rem 0;border-radius:var(--radius-sm);transition:color .18s var(--ease)}.toast-close:hover{color:var(--text-strong)}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(min-width:768px){.shell-header{padding:var(--space-3) var(--space-5);gap:var(--space-4)}.shell-logo{height:36px}.shell-title{font-size:1.1rem}.shell-main{padding:var(--space-5)}.data-toolbar{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:var(--space-4)}.data-add{align-self:auto;flex-shrink:0}.filters{flex-direction:row;align-items:center;flex:1;flex-wrap:wrap}.filters-search{flex:1;min-width:220px}.filters-select{flex:0 0 auto;width:auto;min-width:180px}.filters-clear{align-self:center}.dialog-backdrop{align-items:center;padding:var(--space-5)}.dialog{max-width:640px;border-radius:var(--radius-xl);max-height:85vh;box-shadow:0 24px 64px -16px #0b12204d,0 4px 12px #0b122014}.dialog-header{border-radius:var(--radius-xl) var(--radius-xl) 0 0}.toast-stack{left:auto;max-width:420px}}
