/* The Grounds — A Living Map */
.grounds-app{
  --paper:#efe7d4; --paper-2:#e7dcc4; --ink:#2f3b30; --ink-soft:#5a5142;
  --line:#9c8f72; --line-soft:#bdb190; --gold:#a8842f; --brass:#8a6d27;
  --green:#3d5a40; --burgundy:#7a3b32; --terra:#b5654a; --shadow:rgba(47,59,48,.22);
  --card:#f6efe0;
  position:relative; width:100%; display:flex; flex-direction:column;
  font-family:"EB Garamond",Iowan Old Style,Palatino,Georgia,serif; color:var(--ink);
  background:var(--paper); border:1px solid var(--line); border-radius:3px; overflow:hidden;
  box-shadow:0 6px 26px var(--shadow);
}
.grounds-app.grounds-full{position:fixed;inset:0;height:100vh;border:none;border-radius:0;z-index:1}
.grounds-app *,.grounds-panel *{box-sizing:border-box}
.grounds-loading{margin:auto;padding:3rem;font-style:italic;color:var(--ink-soft)}

.grounds-app::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;mix-blend-mode:multiply;z-index:5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}

/* header */
.g-head{display:flex;align-items:baseline;gap:.9rem;flex-wrap:wrap;padding:.55rem 1.1rem .5rem;
  border-bottom:1px solid var(--line);background:linear-gradient(var(--paper),var(--paper-2));z-index:6}
.g-head .g-title{font-family:"Cinzel",serif;font-weight:600;letter-spacing:.08em;font-size:1.18rem;color:var(--ink)}
.g-head .g-sub{font-style:italic;color:var(--ink-soft);font-size:.98rem}
.g-head .g-metrics{margin-left:auto;font-size:.82rem;color:var(--ink-soft);font-variant:small-caps;letter-spacing:.06em;text-align:right;line-height:1.25}
.g-head .g-metrics b{color:var(--brass);font-weight:600}

/* toolbar */
.g-tools{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap;padding:.45rem 1.1rem;
  border-bottom:1px solid var(--line-soft);background:var(--paper);z-index:6}
.g-btn{font-family:inherit;font-size:.92rem;color:var(--ink);cursor:pointer;background:var(--card);
  border:1px solid var(--line);border-radius:2px;padding:.32rem .7rem;letter-spacing:.02em;
  transition:all .15s;display:inline-flex;align-items:center;gap:.35rem}
.g-btn:hover{background:#fff7e8;border-color:var(--gold)}
.g-btn.primary{background:var(--green);color:#f2ecd8;border-color:var(--green)}
.g-btn.primary:hover{background:#34502f}
.g-btn.active{background:var(--gold);color:#fff;border-color:var(--brass)}
.g-btn.ghost{background:transparent;border-color:transparent}
.g-btn.ghost:hover{background:#fff7e8}
.g-sep{width:1px;height:22px;background:var(--line-soft);margin:0 .25rem}
.g-search{font-family:inherit;font-size:.92rem;padding:.32rem .55rem;border:1px solid var(--line);border-radius:2px;background:var(--card);min-width:150px}
.g-search:focus{outline:none;border-color:var(--gold)}
.g-filters{display:flex;gap:.3rem;flex-wrap:wrap;margin-left:.2rem}
.g-chip{font-size:.78rem;padding:.18rem .5rem;border:1px solid var(--line-soft);border-radius:20px;cursor:pointer;
  background:var(--card);display:inline-flex;align-items:center;gap:.3rem;user-select:none}
.g-chip .dot{width:9px;height:9px;border-radius:50%}
.g-chip.off{opacity:.4;text-decoration:line-through}

/* stage */
.g-stage{position:relative;flex:1;overflow:hidden;cursor:grab;background:#dccfae}
.g-stage.placing,.g-stage.moving,.g-stage.bedding{cursor:crosshair}
.g-stage.panning{cursor:grabbing}
.g-stage svg.g-map{position:absolute;inset:0;width:100%;height:100%;touch-action:none;display:block}
.g-parcel{fill:none;stroke:var(--ink);stroke-width:2.5;vector-effect:non-scaling-stroke;filter:drop-shadow(0 2px 4px var(--shadow))}
.g-plat{fill:none;stroke:var(--line);stroke-width:1;stroke-dasharray:5 4;vector-effect:non-scaling-stroke;opacity:.7}
.g-bed{fill-opacity:.22;stroke-width:2;vector-effect:non-scaling-stroke;cursor:pointer}
.g-bed.sel{stroke:var(--gold);stroke-width:3}
.g-bedlabel text{font-family:"EB Garamond",serif;fill:var(--ink);text-anchor:middle;paint-order:stroke;stroke:rgba(246,239,224,.8);stroke-width:3px;pointer-events:none}
.g-draft{fill:rgba(168,132,47,.18);stroke:var(--gold);stroke-width:2;vector-effect:non-scaling-stroke;stroke-dasharray:4 3}
.g-pin circle.body{stroke:#fff;stroke-width:1.5;cursor:pointer;filter:drop-shadow(0 1px 1.5px var(--shadow))}
.g-pin.sel circle.ring{fill:none;stroke:var(--gold);stroke-width:2}
.g-pin text{font-family:"EB Garamond",serif;font-size:11px;fill:var(--ink);paint-order:stroke;stroke:rgba(246,239,224,.85);stroke-width:3px;text-anchor:middle;pointer-events:none}
.g-pin.dim{opacity:.16}
.g-grid{stroke:var(--line-soft);stroke-width:.6;vector-effect:non-scaling-stroke;opacity:.14}

/* overlays */
.g-compass{position:absolute;right:14px;bottom:14px;width:70px;height:70px;opacity:.8;pointer-events:none;z-index:4}
.g-scalebar{position:absolute;left:14px;bottom:16px;z-index:4;font-size:.72rem;color:var(--ink);font-variant:small-caps;letter-spacing:.05em;text-align:center;text-shadow:0 1px 2px var(--paper)}
.g-scalebar .bar{height:7px;border:1px solid var(--ink);border-top:none;margin-bottom:2px}
.g-zoom{position:absolute;left:14px;top:14px;display:flex;flex-direction:column;gap:4px;z-index:4}
.g-zoom .g-btn{width:34px;height:34px;justify-content:center;font-size:1.2rem;padding:0}
.g-hint{position:absolute;left:50%;top:14px;transform:translateX(-50%);z-index:5;background:var(--green);color:#f2ecd8;
  padding:.4rem .85rem;border-radius:3px;font-size:.9rem;box-shadow:0 3px 10px var(--shadow);display:none}
.g-hint.show{display:block}

/* calibration panel */
.g-cal{position:absolute;left:14px;bottom:64px;z-index:5;background:var(--card);border:1px solid var(--line);border-radius:3px;
  padding:.7rem .8rem;box-shadow:0 3px 12px var(--shadow);width:240px;display:none}
.g-cal.show{display:block}
.g-cal h4{margin:0 0 .4rem;font-variant:small-caps;letter-spacing:.06em;font-size:.85rem}
.g-cal label{font-size:.76rem;font-variant:small-caps;letter-spacing:.05em;display:block;margin:.4rem 0 .1rem}
.g-cal input[type=range]{width:100%}
.g-cal .crow{display:flex;gap:.4rem;margin-top:.5rem;flex-wrap:wrap}

/* panel */
.grounds-panel{position:fixed;top:0;right:0;height:100vh;width:392px;max-width:92vw;z-index:100000;
  background:var(--card);border-left:1px solid var(--line);box-shadow:-6px 0 24px var(--shadow);
  transform:translateX(100%);transition:transform .28s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;
  font-family:"EB Garamond",Iowan Old Style,Palatino,Georgia,serif;color:var(--ink);
  --card:#f6efe0;--ink:#2f3b30;--ink-soft:#5a5142;--line:#9c8f72;--line-soft:#bdb190;--gold:#a8842f;--brass:#8a6d27;--green:#3d5a40;--burgundy:#7a3b32;--shadow:rgba(47,59,48,.22)}
.grounds-panel.open{transform:none}
.grounds-panel .phead{display:flex;align-items:center;padding:.55rem 1.1rem;border-bottom:1px solid var(--line-soft)}
.grounds-panel .phead .lab{font-variant:small-caps;letter-spacing:.08em;color:var(--ink-soft);font-size:.8rem}
.grounds-panel .pbody{overflow:auto;padding:1rem 1.15rem 2rem;flex:1}
.grounds-panel h2{font-family:"Playfair Display",serif;margin:.1rem 0;font-size:1.45rem;font-weight:700;line-height:1.1}
.grounds-panel .botanical{font-style:italic;color:var(--brass);font-size:1.02rem;margin:0 0 .5rem}
.g-cattag{display:inline-flex;align-items:center;gap:.4rem;font-variant:small-caps;letter-spacing:.06em;font-size:.82rem;color:var(--ink-soft);margin-bottom:.6rem}
.g-cattag .dot{width:11px;height:11px;border-radius:50%}
.g-field{margin:.55rem 0}
.g-field label{display:block;font-variant:small-caps;letter-spacing:.07em;font-size:.78rem;color:var(--ink-soft);margin-bottom:.18rem}
.g-field input,.g-field select,.g-field textarea{width:100%;font-family:inherit;font-size:.95rem;padding:.4rem .5rem;border:1px solid var(--line-soft);border-radius:2px;background:#fbf6ea;color:var(--ink)}
.g-field textarea{resize:vertical;min-height:62px;line-height:1.4}
.g-field input:focus,.g-field textarea:focus,.g-field select:focus{outline:none;border-color:var(--gold)}
.g-row2{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
.g-rule{border:none;border-top:1px solid var(--line-soft);margin:1rem 0 .6rem}
.g-rule span{font-variant:small-caps;letter-spacing:.1em;font-size:.74rem;color:var(--brass);background:var(--card);padding:0 .5rem;position:relative;top:-.7rem}
.g-readout p{margin:.3rem 0;line-height:1.5}
.g-readout .glab{font-variant:small-caps;letter-spacing:.06em;color:var(--ink-soft);font-size:.8rem;margin-right:.4rem}
.g-readout .facts{white-space:pre-wrap;line-height:1.55;margin-top:.3rem}
.g-statuspill{display:inline-block;padding:.12rem .55rem;border-radius:20px;font-size:.78rem;font-variant:small-caps;letter-spacing:.05em}
.g-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}
.g-aibtn{width:100%;justify-content:center;border-style:dashed;color:var(--brass)}
.g-ainote{font-size:.8rem;color:var(--ink-soft);font-style:italic;margin:.4rem 0}
.g-closeX{margin-left:auto;background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--ink-soft);line-height:1}
.g-spin{display:inline-block;width:13px;height:13px;border:2px solid var(--brass);border-top-color:transparent;border-radius:50%;animation:gsp .7s linear infinite;vertical-align:-2px}
@keyframes gsp{to{transform:rotate(360deg)}}

/* photos */
.g-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;margin-top:.4rem}
.g-photos img{width:100%;height:78px;object-fit:cover;border:1px solid var(--line-soft);border-radius:2px;cursor:pointer}
.g-photo-edit{position:relative}
.g-photo-edit button{position:absolute;top:2px;right:2px;background:var(--burgundy);color:#fff;border:none;border-radius:50%;width:20px;height:20px;cursor:pointer;font-size:.8rem;line-height:1}
.g-lightbox{position:fixed;inset:0;background:rgba(20,24,18,.9);z-index:100001;display:none;align-items:center;justify-content:center}
.g-lightbox.show{display:flex}
.g-lightbox img{max-width:92vw;max-height:92vh;border:3px solid var(--paper);box-shadow:0 0 40px #000}

.g-toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:#2f3b30;color:#efe7d4;padding:.5rem .9rem;border-radius:3px;font-size:.9rem;z-index:100002;opacity:0;transition:opacity .25s;pointer-events:none;font-family:"EB Garamond",serif}
.g-toast.show{opacity:.96}
.g-readonly-note{font-size:.78rem;color:var(--ink-soft);font-style:italic;padding:.2rem .4rem}
@media(max-width:560px){.g-head .g-metrics{display:none}}

/* species lookup */
.grounds-panel .g-lookup-row{display:flex;gap:.5rem;margin:.4rem 0 .2rem;flex-wrap:wrap}
.grounds-panel .g-lookup-row .g-btn{flex:1;justify-content:center;border-style:dashed;color:var(--brass)}
.grounds-panel .g-cands{display:flex;flex-direction:column;gap:.35rem;margin:.3rem 0}
.grounds-panel .g-cand{display:flex;align-items:center;gap:.6rem;padding:.35rem;border:1px solid var(--line-soft);
  border-radius:3px;cursor:pointer;background:#fbf6ea;transition:all .12s}
.grounds-panel .g-cand:hover{border-color:var(--gold);background:#fff7e8}
.grounds-panel .g-cand img{width:46px;height:46px;object-fit:cover;border-radius:2px;flex:none}
.grounds-panel .g-cand-noimg{width:46px;height:46px;display:flex;align-items:center;justify-content:center;
  background:#e7dcc4;border-radius:2px;font-size:1.3rem;flex:none}
.grounds-panel .g-cand-txt{font-size:.92rem;line-height:1.25}
.grounds-panel .g-cand-loading{font-style:italic;color:var(--ink-soft);font-size:.88rem;padding:.3rem 0}
.grounds-panel .g-sources-list{font-size:.9rem;line-height:1.5;word-break:break-word}
.grounds-panel .g-sources-list a{color:var(--brass)}
