:root{--primary: #1e242b;--primary-hover: #2c353f;--on-primary: #f3f5f7;--accent: #f26419;--accent-hover: #d8530c;--accent-tint: #fdebe0;--on-accent: #ffffff;--bg: #f6f7f9;--surface: #ffffff;--panel: #eef0f3;--hairline: #e1e4e9;--muted: #5b6470;--ink: #161b21;--ink-soft: #2c333b;--green: #1e8e5a;--green-tint: #e4f4ec;--amber: #d39a00;--amber-tint: #fdf2d8;--red: #d14343;--red-tint: #fbe5e5;--info: #2b6cb0;--info-tint: #e6effb;--font-head: "Archivo", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--font-plate: "Archivo", sans-serif;--fz-xs: 11px;--fz-sm: 12px;--fz-md: 13px;--fz-base: 14px;--fz-lg: 16px;--fz-xl: 19px;--fz-2xl: 24px;--fz-3xl: 30px;--fz-4xl: 40px;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-black: 800;--lh-tight: 1.2;--lh-snug: 1.4;--lh-base: 1.6;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 40px;--space-9: 56px;--space-10: 72px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 16px;--radius-pill: 999px;--border-thin: 1px;--border-med: 2px;--border-thick: 3px;--border-accent: 4px;--shadow-sm: 0 1px 2px rgba(20, 27, 33, .06);--shadow-md: 0 2px 8px rgba(20, 27, 33, .08);--shadow-lg: 0 10px 30px rgba(20, 27, 33, .18);--sidebar-w: 248px;--topbar-h: 60px;--bottombar-h: 64px;--content-max: 1280px;--touch: 48px;--tap-lg: 56px;--ls-1: .3px;--ls-2: .4px;--ls-3: .5px;--col-tile: 220px;--col-detail: 200px;--modal-w: 620px;--login-w: 420px;--ease: cubic-bezier(.2, .7, .3, 1);--dur-fast: .12s;--dur: .2s;--z-sticky: 50;--z-overlay: 200;--z-modal: 300;--z-toast: 400;--sidebar-display: flex;--bottombar-display: none;--content-pad-x: var(--space-8);--content-pad-bottom: var(--space-8);--diary-cols-min: 160px}@media (max-width: 640px){:root{--sidebar-display: none;--bottombar-display: flex;--content-pad-x: var(--space-4);--content-pad-bottom: calc(var(--bottombar-h) + var(--space-6));--diary-cols-min: 120px}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--ink);font-size:var(--fz-base);line-height:var(--lh-base);-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:var(--font-head);font-weight:var(--fw-bold);line-height:var(--lh-tight)}a{color:var(--accent-hover);text-decoration:none}button{font-family:var(--font-body);cursor:pointer}.shell{display:grid;grid-template-columns:auto 1fr;min-height:100%}.sidebar{display:var(--sidebar-display);flex-direction:column;width:var(--sidebar-w);background:var(--primary);color:var(--on-primary);position:sticky;top:0;height:100vh;padding:var(--space-5) var(--space-3)}.sidebar .brand{font-family:var(--font-head);font-weight:var(--fw-black);font-size:var(--fz-xl);padding:var(--space-2) var(--space-3) var(--space-5);letter-spacing:-.01em}.sidebar .brand small{display:block;font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--accent)}.nav{display:flex;flex-direction:column;gap:var(--space-1);overflow-y:auto;flex:1}.nav a{display:flex;align-items:center;gap:var(--space-3);min-height:var(--touch);padding:0 var(--space-3);border-radius:var(--radius-md);color:var(--on-primary);opacity:.82;font-weight:var(--fw-medium);font-size:var(--fz-md)}.nav a .ic{width:var(--space-5);text-align:center}.nav a:hover{background:var(--primary-hover);opacity:1}.nav a.active{background:var(--accent);color:var(--on-accent);opacity:1}.nav .badge-dot{margin-left:auto;background:var(--accent);color:var(--on-accent);border-radius:var(--radius-pill);font-size:var(--fz-xs);padding:0 var(--space-2);font-weight:var(--fw-bold)}.sidebar .userbox{border-top:var(--border-thin) solid var(--primary-hover);padding-top:var(--space-3);margin-top:var(--space-3);font-size:var(--fz-md)}.sidebar .userbox .name{font-weight:var(--fw-bold)}.sidebar .userbox .role{color:var(--accent);text-transform:uppercase;font-size:var(--fz-xs);letter-spacing:var(--ls-2)}.sync{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--fz-sm)}.sync .dot{width:var(--space-2);height:var(--space-2);border-radius:var(--radius-pill)}.sync.online .dot{background:var(--green)}.sync.syncing .dot{background:var(--amber)}.sync.offline .dot{background:var(--red)}.main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;gap:var(--space-4);min-height:var(--topbar-h);padding:0 var(--content-pad-x);border-bottom:var(--border-thin) solid var(--hairline);background:var(--surface);position:sticky;top:0;z-index:var(--z-sticky)}.topbar h1{font-size:var(--fz-2xl)}.topbar .spacer{flex:1}.content{padding:var(--space-6) var(--content-pad-x) var(--content-pad-bottom);max-width:var(--content-max);width:100%}.bottombar{display:var(--bottombar-display);position:fixed;bottom:0;left:0;right:0;height:var(--bottombar-h);background:var(--primary);z-index:var(--z-sticky);justify-content:space-around;align-items:stretch}.bottombar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);color:var(--on-primary);opacity:.8;font-size:var(--fz-xs);flex:1;min-height:var(--touch)}.bottombar a.active{color:var(--accent);opacity:1}.card{background:var(--surface);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);box-shadow:var(--shadow-sm)}.grid{display:grid;gap:var(--space-4)}.grid.cols{grid-template-columns:repeat(auto-fill,minmax(var(--diary-cols-min),1fr))}.tiles{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(var(--col-tile),1fr))}.tile{background:var(--surface);border:var(--border-thin) solid var(--hairline);border-left:var(--border-accent) solid var(--accent);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-sm)}.tile .k{color:var(--muted);font-size:var(--fz-sm);text-transform:uppercase;letter-spacing:var(--ls-2)}.tile .v{font-family:var(--font-head);font-size:var(--fz-3xl);font-weight:var(--fw-black)}.tile.accent .v{color:var(--accent)}table{width:100%;border-collapse:collapse;font-size:var(--fz-md)}th{text-align:left;font-size:var(--fz-xs);text-transform:uppercase;letter-spacing:var(--ls-3);color:var(--muted);padding:var(--space-2) var(--space-3);border-bottom:var(--border-med) solid var(--hairline);background:var(--panel)}td{padding:var(--space-3);border-bottom:var(--border-thin) solid var(--hairline);vertical-align:middle}tr:hover td{background:var(--panel)}tr.clickable{cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:var(--touch);padding:0 var(--space-5);border-radius:var(--radius-md);border:var(--border-thin) solid transparent;font-weight:var(--fw-semibold);font-size:var(--fz-base);background:var(--panel);color:var(--ink)}.btn:hover{background:var(--hairline)}.btn.primary{background:var(--accent);color:var(--on-accent)}.btn.primary:hover{background:var(--accent-hover)}.btn.dark{background:var(--primary);color:var(--on-primary)}.btn.ghost{background:transparent;border-color:var(--hairline)}.btn.sm{min-height:var(--space-8);padding:0 var(--space-3);font-size:var(--fz-md)}.btn.danger{background:var(--red);color:var(--on-accent);border-color:var(--red)}.btn.danger:hover{background:var(--red);filter:brightness(.93)}.btn.ghost.danger{background:transparent;color:var(--red);border-color:var(--red)}.btn.ghost.danger:hover{background:var(--red-tint);filter:none}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--fz-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--ls-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.badge.green{background:var(--green-tint);color:var(--green)}.badge.amber{background:var(--amber-tint);color:var(--amber)}.badge.red{background:var(--red-tint);color:var(--red)}.badge.info{background:var(--info-tint);color:var(--info)}.badge.neutral{background:var(--panel);color:var(--muted)}.plate{display:inline-block;font-family:var(--font-plate);font-weight:var(--fw-black);letter-spacing:.06em;background:var(--amber);color:var(--ink);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);border:var(--border-med) solid var(--ink)}.field{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3)}.field label{font-size:var(--fz-sm);font-weight:var(--fw-semibold);color:var(--muted)}.field input,.field select,.field textarea{min-height:var(--touch);padding:0 var(--space-3);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-md);font-size:var(--fz-base);font-family:var(--font-body);background:var(--surface);color:var(--ink)}.field textarea{padding:var(--space-2) var(--space-3);min-height:var(--space-9);line-height:var(--lh-snug)}.field input:focus,.field select:focus,.field textarea:focus{outline:var(--border-med) solid var(--accent);border-color:var(--accent)}.row{display:flex;gap:var(--space-3);flex-wrap:wrap;align-items:flex-end}.row>*{flex:1;min-width:0}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#141b218c;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.modal{background:var(--surface);border-radius:var(--radius-xl);padding:var(--space-6);width:100%;max-width:var(--modal-w);max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal h2{font-size:var(--fz-xl);margin-bottom:var(--space-4)}.login-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;background:var(--primary);padding:var(--space-4)}.login-card{background:var(--surface);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:var(--login-w);box-shadow:var(--shadow-lg)}.login-card .brand{font-family:var(--font-head);font-weight:var(--fw-black);font-size:var(--fz-2xl);text-align:center;margin-bottom:var(--space-2)}.login-card .brandbar{height:var(--space-1);border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--primary) 0 60%,var(--accent) 60% 100%);margin-bottom:var(--space-6)}.staff-grid{display:grid;gap:var(--space-3);grid-template-columns:1fr 1fr}.staff-btn{text-align:left;padding:var(--space-4);border-radius:var(--radius-lg);border:var(--border-med) solid var(--hairline);background:var(--surface);min-height:var(--tap-lg)}.staff-btn.sel{border-color:var(--accent);background:var(--accent-tint)}.staff-btn .nm{font-weight:var(--fw-bold)}.staff-btn .rl{font-size:var(--fz-xs);text-transform:uppercase;color:var(--muted)}.pin{display:flex;gap:var(--space-2);justify-content:center;margin:var(--space-4) 0}.pin input{width:var(--space-8);height:var(--tap-lg);text-align:center;font-size:var(--fz-2xl);border:var(--border-med) solid var(--hairline);border-radius:var(--radius-md)}.muted{color:var(--muted)}.right{text-align:right}.mono{font-family:var(--font-plate)}.head-figure{font-family:var(--font-head);font-weight:var(--fw-black)}.toolbar{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap;margin-bottom:var(--space-4)}.toolbar .spacer{flex:1}.section-title{font-size:var(--fz-lg);margin:var(--space-5) 0 var(--space-3)}.empty{text-align:center;color:var(--muted);padding:var(--space-8)}.spinner{display:inline-block;width:var(--space-5);height:var(--space-5);border:var(--border-med) solid var(--hairline);border-top-color:var(--accent);border-radius:var(--radius-pill);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.detail-grid{display:grid;gap:var(--space-3) var(--space-5);grid-template-columns:repeat(auto-fill,minmax(var(--col-detail),1fr))}.kv .k{font-size:var(--fz-sm);color:var(--muted)}.kv .v{font-weight:var(--fw-semibold)}.timeline{border-left:var(--border-med) solid var(--hairline);padding-left:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.timeline .ev{position:relative}.timeline .ev:before{content:"";position:absolute;left:calc(-1 * var(--space-4) - var(--border-med));top:var(--space-1);width:var(--space-2);height:var(--space-2);border-radius:var(--radius-pill);background:var(--accent)}.rag-tabs{display:flex;gap:var(--space-2)}.rag-pick{flex:1;min-height:var(--tap-lg);border-radius:var(--radius-md);border:var(--border-med) solid var(--hairline);font-weight:var(--fw-bold);background:var(--surface)}.rag-pick.green.on{background:var(--green-tint);border-color:var(--green);color:var(--green)}.rag-pick.amber.on{background:var(--amber-tint);border-color:var(--amber);color:var(--amber)}.rag-pick.red.on{background:var(--red-tint);border-color:var(--red);color:var(--red)}.signature-pad{border:var(--border-med) dashed var(--hairline);border-radius:var(--radius-md);touch-action:none;width:100%;background:var(--surface)}.sidebar{height:100vh;height:100dvh}.login-wrap{min-height:100vh;min-height:100dvh}html{-webkit-text-size-adjust:100%}a,button,.btn,.clickable,.nav a,.bottombar a,.bottombar button,input,select,textarea{-webkit-tap-highlight-color:transparent}.btn,.nav a,.bottombar a,.bottombar button,.clickable{touch-action:manipulation}.board{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}img,video,canvas,svg.media{max-width:100%;height:auto}@media (max-width: 1024px){table tbody tr:hover td,table tbody tr.clickable:hover td,.tbl tbody tr:hover td,.tbl tbody tr.clickable:hover td,tr.clickable:hover td,.tbl tr:hover td{background:transparent}table tbody tr:hover,table tbody tr.clickable:hover,.tbl tbody tr:hover,.tbl tbody tr.clickable:hover{background:var(--surface)}.nav a:hover{background:transparent;opacity:.82}.btn:hover{background:var(--panel)}.btn.primary:hover{background:var(--accent)}.btn.dark:hover{background:var(--primary)}.btn.ghost:hover{background:transparent}.btn.danger:hover{filter:none}.btn.ghost.danger:hover{background:transparent;filter:none}.clickable:hover,.card:hover,.tile:hover{background:var(--surface)}}@media (max-width: 1024px){.field input,.field select,.field textarea,input,select,textarea{font-size:16px}.btn,button,.nav a,.clickable,.staff-btn{min-height:var(--touch)}.btn.sm,button.sm,.iconbtn,.icon-btn,.btn-icon,.btn.icon{min-height:44px;min-width:44px}}@media (max-width: 1024px){table{display:block;width:100%}table thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}table tbody{display:grid;gap:var(--space-2);grid-template-columns:1fr;min-width:0}table tr{display:block;background:var(--surface);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);min-width:0;overflow-wrap:break-word}table td{display:inline;padding:0;border:0;white-space:normal;vertical-align:baseline;min-width:0}table td:first-child{display:block;font-weight:var(--fw-bold);font-size:var(--fz-base);color:var(--ink);margin-bottom:2px}table td:first-child:before{content:""}table td:not(:first-child){font-size:var(--fz-sm);color:var(--muted)}table td:not(:first-child):before{content:"·";color:var(--hairline);margin:0 var(--space-1)}table td:nth-child(2):before{content:"";margin:0}table td.row-actions,table td:has(>button),table td:has(>a.btn){display:block;margin-top:var(--space-2);font-size:var(--fz-md)}table td:not(:first-child).row-actions:before,table td:not(:first-child):has(>button):before,table td:not(:first-child):has(>a.btn):before{content:"";margin:0}table td:empty{display:none}}@media (min-width: 641px) and (max-width: 1024px){table tbody{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}}@media (max-width: 640px){.shell{grid-template-columns:1fr}table tbody{grid-template-columns:1fr;gap:0;background:var(--surface);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-md);overflow:hidden}table tr{border:0;border-bottom:var(--border-thin) solid var(--hairline);border-radius:0;padding:6px var(--space-3)}table tr:last-child{border-bottom:0}table tr{display:flow-root}table td:first-child{margin-bottom:0;line-height:var(--lh-tight)}table td:not(:first-child){line-height:var(--lh-tight)}table td.row-actions,table td:has(>button),table td:has(>a.btn){float:none;clear:both;display:flex;gap:var(--space-2);width:100%;margin:var(--space-2) 0 0}table td.row-actions>.btn,table td.row-actions>button,table td:has(>button)>button,table td:has(>button)>.btn,table td:has(>a.btn)>a.btn{flex:1 1 0;min-width:0;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.tile-grid,.grid.cols,.tiles{grid-template-columns:1fr}.grid.kpis,.kpis,.kpi-row,.stat-grid{grid-template-columns:1fr 1fr;gap:var(--space-2)}.kpi{padding:var(--space-3);min-width:0}.kpi>*:not(:first-child),.kpi .num,.kpi .value,.kpi .figure,.kpi strong,.kpi b{font-size:var(--fz-xl);line-height:var(--lh-tight);white-space:nowrap;overflow-wrap:normal}.content,.topbar{padding-left:max(var(--space-3),env(safe-area-inset-left));padding-right:max(var(--space-3),env(safe-area-inset-right))}.content>.card,.card{padding:var(--space-3)}.bottombar{height:calc(var(--bottombar-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}.modal .toolbar:not(:first-child),.modal .actions,.modal .form-actions{display:flex;gap:var(--space-2);width:100%;margin-top:var(--space-4)}.modal .toolbar:not(:first-child)>.btn,.modal .toolbar:not(:first-child)>button,.modal .actions>.btn,.modal .actions>button{flex:1 1 0;min-height:48px}.modal .toolbar:not(:first-child)>.spacer{display:none}.modal form>.btn,.modal>.btn{display:block;width:100%;margin-top:var(--space-2);min-height:48px}.overlay{padding:0;align-items:stretch}.modal{width:100%;max-width:100%;height:100dvh;max-height:none;border-radius:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 var(--space-4) calc(var(--space-7) + env(safe-area-inset-bottom))}.modal>.toolbar:first-child,.modal h2:first-child{position:sticky;top:0;z-index:2;background:var(--surface);margin:0 calc(-1 * var(--space-4)) var(--space-3);padding:max(var(--space-4),env(safe-area-inset-top)) var(--space-4) var(--space-3);border-bottom:var(--border-thin) solid var(--hairline)}.staff-grid{grid-template-columns:1fr}.staff-btn{min-height:var(--touch);text-align:left}.pin{display:flex;justify-content:center;margin:var(--space-4) 0}.pin input{width:100%;max-width:280px;min-height:56px;font-size:1.5rem;text-align:center;letter-spacing:.4em}}.bottombar button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--on-primary);font-size:var(--fz-xs);opacity:.8;background:none;border:0;min-height:var(--touch)}.bottombar button.active{color:var(--accent);opacity:1}.mobile-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#141b2180;display:flex;flex-direction:column;justify-content:flex-end}.mobile-menu .sheet{background:var(--surface);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);max-height:85dvh;overflow-y:auto;padding:var(--space-3) var(--space-4) calc(var(--space-6) + env(safe-area-inset-bottom));box-shadow:var(--shadow-lg)}.mobile-menu .sheet-handle{width:40px;height:4px;border-radius:var(--radius-pill);background:var(--hairline);margin:0 auto var(--space-3)}.mobile-menu .sheet-head{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.mobile-menu .sheet-head .name{font-weight:var(--fw-semibold);font-size:var(--fz-md)}.mobile-menu .sheet-head .role{font-size:var(--fz-xs);color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-2)}.mobile-menu .sheet-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.mobile-menu .sheet-grid a{display:flex;align-items:center;gap:var(--space-3);min-height:var(--touch);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:var(--border-thin) solid var(--hairline);color:var(--ink);font-weight:var(--fw-semibold);font-size:var(--fz-md)}.mobile-menu .sheet-grid a.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.mobile-menu .sheet-grid a .ic{width:18px;height:18px}
