html{overflow-x:clip}:root{--bg: #f3f1ea;--ink: #112434;--muted: #4d6274;--line: #d8d4c7;--surface: #fffdf7;--surface-soft: #f3f0e6;--green: #1f7a4d;--green-dark: #145534;--blue: #1e4f79;--gold: #c58e2f;--red: #b42318;--shadow: 0 18px 45px rgba(28, 33, 41, .09);color:var(--ink);font-family:Manrope,IBM Plex Sans,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;min-width:0;min-height:100vh;background:radial-gradient(circle at 10% 10%,rgba(197,142,47,.16),transparent 38%),radial-gradient(circle at 90% 18%,rgba(31,122,77,.14),transparent 42%),var(--bg)}button,input,select{font:inherit;max-width:100%}button,a.ghost{cursor:pointer;min-height:42px;border-radius:10px;padding:9px 14px;font-weight:800}input,select{width:100%;min-height:44px;border:1px solid var(--line);border-radius:10px;padding:9px 10px;background:#fff}label{display:grid;gap:7px;color:var(--muted);font-size:.9rem;font-weight:800}h1,h2,p{margin:0}.app-shell{min-height:100vh}.eyebrow{color:var(--muted);font-size:.78rem;font-weight:900;letter-spacing:.03em;text-transform:uppercase}.appbar{display:flex;align-items:center;gap:0;min-width:0;padding:0 20px;height:56px;background:var(--ink);color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px #00000038}.appbar-brand{display:flex;align-items:center;gap:9px;padding-right:20px;border-right:1px solid rgba(255,255,255,.13);flex-shrink:0;text-decoration:none}.brand-icon{font-size:1.3rem;line-height:1}.brand-name{font-size:1.08rem;font-weight:900;letter-spacing:-.02em;color:#fff}.appbar-nav{display:flex;align-items:center;gap:2px;flex:1;min-width:0;padding:0 14px;overflow-x:auto;scrollbar-width:none}.appbar-nav::-webkit-scrollbar{display:none}.appbar-user{display:flex;align-items:center;gap:10px;flex-shrink:0;min-width:0;padding-left:18px;border-left:1px solid rgba(255,255,255,.13)}.user-pill{display:flex;align-items:center;gap:7px}.user-avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--gold);color:#fff;font-size:.78rem;font-weight:900;flex-shrink:0}.user-name{font-size:.86rem;font-weight:700;color:#fff}.user-role{font-size:.76rem;color:#ffffff85}.ghost-sm{cursor:pointer;display:inline-flex;align-items:center;justify-content:center;min-height:32px;border-radius:8px;padding:5px 12px;font-weight:700;font-size:.84rem;font:inherit;border:1px solid rgba(255,255,255,.26);color:#ffffffc7;background:transparent}.ghost-sm:hover{background:#ffffff1a;color:#fff}.workspace{display:grid;gap:18px;min-width:0;width:min(1180px,100%);margin:0 auto;padding:16px 20px 32px}.subbar{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:14px}.campaign-label{display:grid;gap:5px;min-width:220px;max-width:360px;color:var(--muted);font-size:.9rem;font-weight:800}.panel{min-width:0;padding:18px;border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:var(--shadow)}.tab{border:none;background:transparent;color:#ffffffa8;min-height:36px;border-radius:7px;padding:5px 14px;font-size:.9rem;font-weight:700;white-space:nowrap}.tab-label-short{display:none}.tab:hover{background:#ffffff17;color:#fff}.tab.is-active{background:#ffffff29;color:#fff}.grid.two{display:grid;grid-template-columns:minmax(300px,1fr) minmax(300px,1fr);gap:18px;min-width:0}.kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}.kpi-card{display:grid;gap:6px;padding:12px;border-radius:10px;border:1px solid #d3dfd7;background:#f3faf6}.kpi-card span{color:var(--muted);font-size:.86rem;font-weight:800}.kpi-card strong{font-size:1.12rem}.summary-grid{display:grid;grid-template-columns:repeat(2,minmax(300px,1fr));gap:18px;min-width:0}.summary-grid .full{grid-column:1 / -1}.summary-kpi{display:flex;align-items:center;flex-wrap:wrap;gap:32px;padding:20px 24px;background:linear-gradient(135deg,var(--green) 0%,#267f52 100%);border-color:transparent;color:#fff}.summary-stat{display:grid;gap:4px}.summary-stat .eyebrow{color:#ffffffb3}.summary-big{font-size:2rem;font-weight:900;letter-spacing:-.03em;color:#fff;line-height:1.1}.summary-sub{font-size:.9rem;color:#ffffffb3}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:16px}.wide{grid-column:1 / -1}.primary{border:1px solid var(--green);color:#fff;background:linear-gradient(135deg,var(--green),#279562)}.primary:hover{background:var(--green-dark)}.ghost{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);color:var(--ink);background:#fff;text-decoration:none}.danger{border:1px solid #f3b8b3;color:var(--red);background:#fff8f7}.small{min-height:32px;padding:6px 9px;font-size:.86rem}.net-card{display:grid;align-content:center;gap:6px;min-height:66px;padding:10px 12px;border:1px solid #c9dfd3;border-radius:8px;background:#f0f8f3}.net-card span{color:var(--muted);font-weight:800}.net-card strong{color:var(--green-dark);font-size:1.35rem}.net-card.negative{border-color:#f3b8b3;background:#fff8f7}.net-card.negative strong{color:var(--red)}.filters{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:12px;margin-top:14px}.table-wrap{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;margin-top:14px;border:1px solid var(--line);border-radius:10px;background:linear-gradient(to right,#fff 30%,#fff0) left,linear-gradient(to left,#d2d4c78c,#fff0) right;background-repeat:no-repeat;background-size:36px 100%,22px 100%;background-attachment:local,scroll}table{width:100%;min-width:640px;border-collapse:collapse;background:#fff}.table-sm table{min-width:240px}.table-xs table{min-width:0}th,td{padding:11px 12px;border-bottom:1px solid var(--line);text-align:left;overflow-wrap:anywhere}th{color:var(--muted);background:var(--surface-soft);font-size:.78rem;text-transform:uppercase}.number{text-align:right;font-variant-numeric:tabular-nums}.strong{font-weight:900}.actions{display:flex;gap:8px;flex-wrap:wrap}.actions.end{justify-content:flex-end}.info-popover{position:relative;width:32px}.info-popover summary{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--line);border-radius:999px;color:var(--blue);background:#fff;font-weight:900;list-style:none;cursor:pointer}.info-popover summary::-webkit-details-marker{display:none}.info-card{position:absolute;z-index:20;top:34px;left:0;display:grid;gap:6px;width:280px;max-width:calc(100vw - 48px);padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow);color:var(--ink);font-size:.88rem}.info-card span{color:var(--muted)}.status{display:inline-flex;border-radius:999px;padding:4px 8px;font-size:.82rem;font-weight:900}.status.active{color:#11633f;background:#dcfce7}.status.annulled{color:var(--red);background:#fee7e4}.totals,.farmer-list,.user-list{display:grid;gap:10px;margin-top:14px}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:18px;min-width:0}.admin-grid .full{grid-column:1 / -1}.inline-edit-form{display:flex;gap:6px;align-items:center}.inline-edit-form input{flex:1;min-width:0;padding:4px 8px;font-size:.9rem}.catalog-add-form{display:flex;gap:10px;align-items:flex-end;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.catalog-add-form label{flex:1;min-width:0;margin-bottom:0}.catalog-actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}button.danger{background:transparent;border:1.5px solid var(--red);color:var(--red)}button.danger:hover{background:var(--red);color:#fff}.checkbox-grid{display:grid;gap:8px;margin:14px 0;max-height:280px;overflow:auto;border:1px solid var(--line);border-radius:10px;padding:10px;background:var(--surface-soft)}.access-status{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin:10px 0 0;font-size:.88rem}.access-count{color:var(--muted)}.access-loading{color:var(--muted);font-style:italic}.access-dirty{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:#fef9c3;color:#7c5e10;font-size:.78rem;font-weight:800}.access-dirty:before{content:"●";font-size:.6rem}.checkbox-grid.is-loading{opacity:.45;pointer-events:none}.check-item{grid-template-columns:auto 1fr auto;align-items:center;gap:10px;font-weight:700;font-size:.9rem;color:var(--ink)}.check-item.changed{background:#fffbeb;border-radius:8px;padding:2px 6px;margin:-2px -6px}.check-item input{width:18px;height:18px;min-height:18px}.change-tag{font-size:.72rem;font-weight:900;padding:2px 7px;border-radius:999px}.change-tag.add{background:#dcfce7;color:#166534}.change-tag.remove{background:#fee2e2;color:#991b1b}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.login-screen,.center-screen{display:grid;place-items:center;min-height:100vh;padding:20px}.login{width:min(430px,100%);display:grid;gap:14px}.notice,.error{padding:12px 14px;border-radius:8px;color:var(--red);background:#fff8f7;border:1px solid #f3b8b3;font-weight:800}.modal-backdrop{position:fixed;inset:0;display:grid;place-items:center;padding:18px;background:#0f172a80;z-index:200}.modal{width:min(520px,100%);background:var(--surface);border-radius:16px;box-shadow:0 24px 64px #00000047;display:flex;flex-direction:column;max-height:85vh;overflow:hidden}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:22px 24px 0}.modal-body{display:grid;gap:14px;padding:16px 24px;overflow-y:auto;flex:1}.modal .ghost-sm{border-color:var(--line);color:var(--ink)}.modal .ghost-sm:hover{background:var(--surface-soft);color:var(--ink)}.modal-footer{display:flex;justify-content:flex-end;align-items:center;gap:10px;padding:14px 24px;border-top:1px solid var(--line)}.modal-hint{color:var(--muted);font-size:.88rem;margin:0 0 12px}.modal-select-all{display:flex;gap:8px;margin-bottom:14px}@media(max-width:980px){.grid.two,.summary-grid,.admin-grid{grid-template-columns:1fr}}@media(max-width:740px){.user-role,.user-name{display:none}.summary-big{font-size:1.5rem}}@media(max-width:680px){.appbar{display:grid;grid-template-columns:minmax(0,1fr) auto;height:auto;padding:10px 14px;gap:8px}.appbar-brand{min-width:0;padding-right:0;border-right:none}.brand-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.appbar-nav{position:fixed;bottom:0;left:0;right:0;order:unset;width:auto;padding:6px 8px calc(6px + env(safe-area-inset-bottom));background:var(--ink);border-top:1px solid rgba(255,255,255,.14);box-shadow:0 -4px 18px #00000047;z-index:99;justify-content:stretch;gap:4px}.appbar-nav .tab{flex:1;text-align:center;padding:10px 4px 8px;font-size:.76rem;min-height:48px;border-radius:10px;white-space:nowrap;line-height:1.2}.tab-label-full{display:none}.tab-label-short{display:inline}th,td{padding:8px 10px;font-size:.84rem}.appbar-user{border-left:none;padding-left:0;margin-left:auto}.ghost-sm{min-height:34px;padding:5px 10px}.workspace{width:100%;gap:14px;padding:14px 14px calc(80px + env(safe-area-inset-bottom))}.panel{padding:14px;border-radius:12px}.subbar{flex-direction:column;align-items:stretch}.campaign-label{max-width:100%}.form-grid,.filters,.kpi-grid{grid-template-columns:1fr}.summary-kpi{align-items:flex-start;gap:8px;padding:16px}.catalog-add-form,.inline-edit-form{display:grid;grid-template-columns:1fr;align-items:stretch}.catalog-actions{justify-content:stretch}.catalog-actions button,.inline-edit-form button,.actions button{flex:1 1 140px}.table-wrap{overflow:visible;border:0;border-radius:0;background:transparent}table,.table-sm table,.table-xs table{display:block;width:100%;min-width:0;background:transparent}thead{display:none}tbody{display:grid;gap:10px}tr{display:grid;gap:0;padding:6px 10px;border:1px solid var(--line);border-radius:10px;background:#fff}td{display:grid;grid-template-columns:minmax(86px,38%) minmax(0,1fr);gap:12px;align-items:start;min-width:0;padding:9px 0;border-bottom:1px solid #ece7dc;text-align:right}td:last-child{border-bottom:0}td:before{content:attr(data-label);color:var(--muted);font-size:.76rem;font-weight:900;text-align:left;text-transform:uppercase}td[colspan]{display:block;text-align:center}td[colspan]:before{content:none}td.number{text-align:right}td.actions{display:grid;grid-template-columns:minmax(86px,38%) minmax(0,1fr);justify-content:stretch}td.actions button{grid-column:2;width:100%}.info-popover{justify-self:end;width:auto}.info-card{position:fixed;top:auto;left:14px;right:14px;bottom:calc(72px + env(safe-area-inset-bottom));width:auto;max-width:none;max-height:48vh;overflow:auto}}
