:root{
  --ink:#212121; --slate-moon:#7F8290; --lit-moon:#F5E8BD; --sun-gold:#DBA833;
  --cloud-gray:#9AA2AA; --rain-blue:#5C85B3; --paper:#f4f1e9; --paper-2:#fbf9f3;
  --line:#d8d2c4; --line-2:#e6e1d5; --muted:#6c665a;
  --steve:#3f6f52;   /* green accent */
  --nick:#8a5a2b;    /* amber/brown accent */
  --accent:var(--steve);
  --ok:#3f8f5b; --warn:#c08a2a; --danger:#b0432f;
  --radius:14px; --shadow:0 1px 2px rgba(0,0,0,.06),0 6px 18px rgba(0,0,0,.05);
  --tap:44px;
}
body[data-log="nick"]{ --accent:var(--nick); }

*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:var(--paper);
  -webkit-text-size-adjust:100%;
}
h1,h2,legend{font-family:Georgia,"Times New Roman",serif}

/* App bar */
.appbar{
  position:sticky; top:0; z-index:20; background:var(--paper-2);
  border-bottom:2px solid var(--accent);
  padding:env(safe-area-inset-top) 0 0;
}
.appbar-row{display:flex; align-items:center; gap:12px; padding:8px 14px; max-width:1100px; margin:0 auto}
.brand{display:flex; align-items:center; gap:7px; font-weight:700}
.brand-mark{color:var(--accent)}
.brand-name{font-family:Georgia,serif; letter-spacing:.3px}
.log-toggle{display:flex; gap:0; margin:0 auto; background:#ece7da; border:1px solid var(--line); border-radius:999px; padding:3px}
.log-btn{
  border:0; background:transparent; padding:8px 14px; border-radius:999px;
  font-weight:600; color:var(--muted); cursor:pointer; min-height:36px; font-size:14px;
}
.log-btn.is-active{ background:var(--accent); color:#fff; box-shadow:var(--shadow) }
.sync-status{display:flex; align-items:center; gap:6px; font-size:12px; color:var(--muted); min-width:84px; justify-content:flex-end}
.sync-status .dot{width:9px; height:9px; border-radius:50%; background:var(--cloud-gray)}
.sync-status[data-state="synced"] .dot{background:var(--ok)}
.sync-status[data-state="pending"] .dot{background:var(--warn)}
.sync-status[data-state="offline"] .dot{background:var(--danger)}

/* Layout */
main{max-width:1100px; margin:0 auto; padding:14px 14px 60px}
.view-title{font-size:22px; margin:6px 2px 12px}
.list-toolbar{display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px}
.toolbar-actions{display:flex; gap:8px; align-items:center}

/* Buttons */
.btn{
  font:inherit; border:1px solid transparent; border-radius:10px; padding:10px 14px;
  min-height:var(--tap); cursor:pointer; font-weight:600; background:#fff; color:var(--ink);
  transition:transform .04s ease, background .15s ease, border-color .15s;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent); color:#fff}
.btn-ghost{background:transparent; border-color:var(--line); color:var(--ink)}
.btn-small{min-height:38px; padding:8px 12px; border:1px solid var(--line)}
.btn-add{background:transparent; border:1px dashed var(--accent); color:var(--accent); width:100%; margin-top:10px}
.btn-danger-ghost{background:transparent; border-color:#e3c4bd; color:var(--danger)}
.btn-wide{width:100%; padding:14px; font-size:16px}

/* Trip list */
.trip-list{list-style:none; margin:0; padding:0; display:grid; gap:10px}
.trip-card{
  display:flex; align-items:center; gap:12px; background:var(--paper-2);
  border:1px solid var(--line); border-left:5px solid var(--accent);
  border-radius:var(--radius); padding:12px 14px; cursor:pointer; box-shadow:var(--shadow);
}
.trip-card:hover{border-color:var(--accent)}
.trip-no-badge{
  flex:0 0 auto; width:42px; height:42px; border-radius:10px; background:var(--accent); color:#fff;
  display:flex; align-items:center; justify-content:center; font-weight:700; font-family:Georgia,serif;
}
.trip-main{flex:1; min-width:0}
.trip-water{font-weight:700}
.trip-meta{font-size:13px; color:var(--muted)}
.trip-catch{flex:0 0 auto; text-align:right; font-size:13px; color:var(--muted)}
.trip-catch b{display:block; font-size:18px; color:var(--ink); font-family:Georgia,serif}
.unsynced-pill{display:inline-block; font-size:11px; color:var(--warn); border:1px solid #e6d4ad; background:#fbf3df; border-radius:999px; padding:1px 7px; margin-left:6px}
.empty-note{color:var(--muted); text-align:center; padding:40px 10px}

/* Cards / form */
.card{
  background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:14px; margin:0 0 14px; box-shadow:var(--shadow);
}
.card-legend{font-size:15px; font-weight:700; padding:0 4px; color:var(--ink)}
.hint{font-weight:400; color:var(--muted); font-size:12px; font-family:inherit}
.auto-tag{font:600 11px/1 sans-serif; background:var(--accent); color:#fff; border-radius:999px; padding:3px 7px; vertical-align:middle}
.field{display:flex; flex-direction:column; gap:5px; margin-bottom:12px}
.field:last-child{margin-bottom:0}
.lab{font-size:13px; color:var(--muted); font-weight:600}
input,textarea,select{
  font:inherit; color:var(--ink); background:#fff; border:1px solid var(--line);
  border-radius:10px; padding:11px 12px; min-height:var(--tap); width:100%;
}
textarea{min-height:auto}
input:focus,textarea:focus{outline:2px solid var(--accent); outline-offset:1px; border-color:var(--accent)}
.grid{display:grid; gap:12px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:1fr 1fr 1fr}
.gauge-site-row{display:flex; gap:6px}
.gauge-site-row input{flex:1}
.usgs-note,.solunar-note{font-size:12px; color:var(--muted); margin:6px 2px 0}
.usgs-note{color:var(--rain-blue)}

/* Form head */
.form-head{
  position:sticky; top:calc(env(safe-area-inset-top) + 52px); z-index:10;
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  background:var(--paper); padding:8px 0; margin-bottom:8px;
}
.form-head-title{flex:1; text-align:center}
.trip-no-wrap{font-weight:600; color:var(--muted); font-size:14px}
.trip-no-input{display:inline-block; width:66px; min-height:36px; padding:6px 8px; margin-left:4px; text-align:center}
.form-head-actions{display:flex; gap:8px}

/* Icon selector rows */
.icon-row{display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-top:4px}
.clarity-row{grid-template-columns:repeat(5,1fr)}
.icon-btn{
  display:flex; flex-direction:column; align-items:center; gap:6px; justify-content:flex-start;
  background:#fff; border:1.5px solid var(--line); border-radius:12px; padding:10px 6px;
  min-height:var(--tap); cursor:pointer; color:var(--ink); font:inherit;
}
.icon-btn svg{width:34px; height:34px; display:block}
.icon-btn .ic-label{font-size:11px; color:var(--muted); text-align:center; line-height:1.15}
.icon-btn.is-on{border-color:var(--accent); background:color-mix(in srgb,var(--accent) 12%,#fff); box-shadow:inset 0 0 0 1px var(--accent)}
.icon-btn.is-on .ic-label{color:var(--ink); font-weight:600}

/* Compass */
.compass{display:grid; grid-template-columns:repeat(8,1fr); gap:6px}
.wind-grid{margin-top:12px}
.compass .icon-btn{padding:8px 2px}
.compass .icon-btn svg{width:26px;height:26px}

/* Repeatable tables */
.repeat-head{display:none}
.repeat-row{
  display:grid; gap:8px; padding:10px; border:1px solid var(--line-2);
  border-radius:12px; margin-bottom:8px; background:#fff;
}
.repeat-row .ri-lab{font-size:11px; color:var(--muted); font-weight:600; margin-bottom:2px; display:block}
.repeat-row .row-index{font-weight:700; color:var(--accent); font-family:Georgia,serif}
.row-del{
  justify-self:end; border:1px solid var(--line); background:#fff; color:var(--danger);
  border-radius:9px; min-height:36px; padding:6px 10px; cursor:pointer; font-size:13px;
}
.flies-cols{grid-template-columns:2fr 1fr 1.4fr 2fr 40px}
.catches-cols{grid-template-columns:30px 1.4fr 0.56fr 1.4fr 1.5fr 0.675fr 0.6fr 1.8fr 40px}

/* Footer */
.form-foot{margin-top:6px}
.move-actions{display:flex; gap:8px; margin-bottom:12px}
.move-actions .btn{flex:1}

/* Dialog */
.dialog{border:0; border-radius:16px; padding:0; max-width:520px; width:92%; box-shadow:0 20px 60px rgba(0,0,0,.3)}
.dialog::backdrop{background:rgba(0,0,0,.4)}
.dialog-body{padding:20px}
.dialog-title{margin:0 0 6px; font-size:19px}
.dialog-sub{font-size:13px; color:var(--muted); margin:0 0 12px}
.dialog-actions{display:flex; justify-content:flex-end; gap:8px; margin-top:14px}

/* Toast */
.toast{
  position:fixed; left:50%; bottom:22px; transform:translateX(-50%);
  background:var(--ink); color:#fff; padding:12px 18px; border-radius:10px; z-index:50;
  box-shadow:0 8px 24px rgba(0,0,0,.25); font-size:14px; max-width:90%;
}

/* Mobile: stack repeat rows into labeled blocks */
@media (max-width:719px){
  .grid-3{grid-template-columns:1fr 1fr}
  .repeat-row{grid-template-columns:1fr 1fr !important}
  .repeat-row .col-wide{grid-column:1 / -1}
  .repeat-row .row-del{grid-column:1 / -1}
}

/* Desktop / tablet: real multi-column tables */
@media (min-width:720px){
  .icon-row{grid-template-columns:repeat(8,1fr)}
  .ri-lab{display:none !important}
  .repeat-head{
    display:grid; gap:8px; padding:0 10px 6px; font-size:12px; color:var(--muted); font-weight:700;
  }
  .repeat-row{align-items:center}
  .flies-cols, .catches-cols{}
  #fliesBody .repeat-row{grid-template-columns:2fr 1fr 1.4fr 2fr 40px}
  #catchesBody .repeat-row{grid-template-columns:30px 1.4fr 0.56fr 1.4fr 1.5fr 0.675fr 0.6fr 1.8fr 40px}
  .repeat-row .row-del{justify-self:center}
}
