:root{
  --green-dark:#00643C; --green-bright:#008453;
  --g70:#6D6E71; --g50:#646567; --g30:#BCBEC0;
  --border:#888A8C;
  --bg:#F7F8F7; --card:#FFFFFF; --line:#E4E7E5;
  --danger:#A32D2D; --danger-bg:#FCEBEB; --danger-line:#BF7E7E;
  --ok:#0F6E56; --ok-bg:#E1F5EE;
  --warn:#854F0B; --warn-bg:#FAEEDA;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Mont","Montserrat",system-ui,-apple-system,sans-serif;
  color:var(--g70);background:var(--bg);font-size:15px;line-height:1.5}
a{color:var(--green-bright);text-decoration:none;transition:color .12s ease}
a:hover{text-decoration:underline}
h1,h2,h3{color:var(--green-dark);font-weight:700;line-height:1.25;margin:0 0 .5rem}
h1{font-size:24px}h2{font-size:19px}h3{font-size:18px}

/* visible focus on every interactive element, not just inputs (WCAG 2.4.7) */
:focus-visible{outline:2px solid var(--green-bright);outline-offset:2px;border-radius:4px}

.topbar{background:var(--green-dark);color:#fff;padding:0 1.25rem;display:flex;align-items:center;
  gap:1.25rem;height:54px}
.topbar .brand{font-weight:700;color:#fff;font-size:17px;letter-spacing:.2px}
.topbar a{color:#E1F5EE;font-size:14px;padding:.4rem 0;border-bottom:2px solid transparent}
.topbar a:hover{color:#fff;text-decoration:none}
.topbar a.active{color:#fff;border-bottom-color:#fff;font-weight:700}
.topbar a:focus-visible{outline-color:#fff}
.topbar .spacer{flex:1}
.topbar .who{font-size:13px;color:#BFE3D4}
.wrap{max-width:1040px;margin:1.5rem auto;padding:0 1.25rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:1.1rem 1.25rem;margin-bottom:1.1rem}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:.55rem .6rem;border-bottom:1px solid var(--line)}
th{color:var(--g50);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.4px}
tr:hover td{background:#FAFBFA}
.num{text-align:right;font-variant-numeric:tabular-nums}
.badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px}
.badge.green{background:var(--ok-bg);color:var(--ok)}
.badge.gray{background:#EEF0EE;color:var(--g70)}
.badge.warn{background:var(--warn-bg);color:var(--warn)}
.badge.trial{background:#FAEEDA;color:var(--warn)}
.badge.danger{background:var(--danger-bg);color:var(--danger)}
input,select,textarea{font:inherit;color:var(--g70);background:#fff;border:1px solid var(--border);
  border-radius:7px;padding:.45rem .55rem;width:100%;transition:border-color .12s ease,box-shadow .12s ease}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green-bright);
  box-shadow:0 0 0 3px rgba(0,132,83,.15)}
label{display:block;font-size:13px;color:var(--g50);margin:.7rem 0 .25rem}
.btn{display:inline-block;background:var(--green-dark);color:#fff;border:none;border-radius:7px;
  padding:.5rem .9rem;font-weight:700;font-size:14px;cursor:pointer;
  transition:background .15s ease,box-shadow .15s ease,transform .05s ease}
.btn:hover{background:var(--green-bright);text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn.sec{background:#fff;color:var(--green-dark);border:1px solid var(--border)}
.btn.sec:hover{background:#F1F5F3}
.btn.danger{background:#fff;color:var(--danger);border:1px solid var(--danger-line)}
.btn.danger:hover{background:var(--danger-bg)}
.btn.sm{padding:.3rem .6rem;font-size:13px}
.flash{padding:.6rem .9rem;border-radius:8px;margin-bottom:.7rem;font-size:14px}
.flash.danger{background:var(--danger-bg);color:var(--danger)}
.flash.success{background:var(--ok-bg);color:var(--ok)}
.flash.warning{background:var(--warn-bg);color:var(--warn)}
.grid{display:grid;gap:12px}
.grid.k3{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
.stat{background:#fff;border:1px solid var(--line);border-radius:10px;padding:.9rem 1rem}
.stat .l{font-size:12px;color:var(--g50);text-transform:uppercase;letter-spacing:.4px}
.stat .v{font-size:24px;font-weight:700;color:var(--green-dark);margin-top:2px}
/* clickable stat cards (Home) read as shortcuts into a filtered view */
a.stat{display:block;color:inherit;text-decoration:none;
  transition:border-color .15s ease,box-shadow .15s ease,transform .08s ease}
a.stat:hover{border-color:var(--green-bright);box-shadow:0 2px 10px rgba(0,100,60,.10);
  text-decoration:none;transform:translateY(-1px)}
.muted{color:var(--g50);font-size:13px}
.row-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.toolbar{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin-bottom:1rem}
.toolbar .spacer{flex:1}
.login-wrap{max-width:380px;margin:8vh auto;padding:0 1rem}
.pill-link{font-size:13px;padding:.3rem .7rem;border:1px solid var(--border);border-radius:20px;
  color:var(--g70);background:#fff;transition:background .15s ease,border-color .15s ease,color .15s ease}
.pill-link:hover{border-color:var(--green-bright);color:var(--green-dark);text-decoration:none}
.pill-link.active{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}
.pill-link.active:hover{background:var(--green-bright);color:#fff}
code{font-family:var(--font-mono,ui-monospace,monospace);background:#EEF0EE;padding:1px 5px;border-radius:4px;font-size:13px}
.appfoot{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--line);color:var(--g50);font-size:12px;text-align:center}

/* disabled buttons (e.g. Save while composition != 100%) — reads clearly as off */
.btn:disabled,.btn[disabled]{background:#EEF0EE;color:var(--border);border:1px solid var(--border);
  cursor:not-allowed;box-shadow:none;transform:none}
.btn:disabled:hover,.btn[disabled]:hover{background:#EEF0EE}

/* keep the running composition total in view while editing a long recipe */
.totals-sticky{position:sticky;bottom:0;z-index:5;box-shadow:0 -3px 12px rgba(0,0,0,.05)}

/* htmx live-preview indicator: hidden until a request is in flight */
.htmx-indicator{opacity:0;transition:opacity .15s ease}
.htmx-request .htmx-indicator,.htmx-request.htmx-indicator{opacity:1}

/* wide data tables scroll horizontally instead of breaking the layout */
.card:has(table){overflow-x:auto;-webkit-overflow-scrolling:touch}

@media (max-width:680px){
  /* let the top nav wrap to multiple lines instead of clipping links */
  .topbar{flex-wrap:wrap;height:auto;padding:.5rem 1rem;gap:.4rem 1rem}
  .topbar .spacer{display:none}
  .topbar a{padding:.25rem 0}
  /* keep wide tables readable; they scroll inside their card */
  .card:has(table) table:not(.table-cards){min-width:560px}
  /* bigger tap targets on touch screens */
  .btn.sm{padding:.45rem .8rem;font-size:14px}
  .pill-link{padding:.45rem .85rem}
  .wrap{margin:1rem auto}
}

/* phone: break list tables into stacked cards so the price is never off-screen */
@media (max-width:560px){
  table.table-cards thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;
    overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
  table.table-cards,table.table-cards tbody,table.table-cards tr,table.table-cards td{display:block;width:100%}
  table.table-cards tr{border:1px solid var(--line);border-radius:10px;margin:.7rem;padding:.3rem 0}
  table.table-cards tr:hover td{background:transparent}
  table.table-cards td{border:none;padding:.35rem .9rem;display:flex;justify-content:space-between;
    align-items:baseline;gap:1rem;text-align:right}
  table.table-cards td::before{content:attr(data-label);color:var(--g50);font-size:11px;
    font-weight:700;text-transform:uppercase;letter-spacing:.4px;text-align:left;flex:0 0 auto}
  table.table-cards td:first-child{font-size:16px;padding-top:.6rem}
  table.table-cards td[colspan]{justify-content:flex-start}
  table.table-cards td[colspan]::before{content:""}
  .card:has(table.table-cards){overflow-x:visible;padding:.3rem 0}
}

/* honor users who ask the OS to reduce motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition:none!important;animation:none!important;scroll-behavior:auto!important}
}
