/* ============================================================
   OpenMap — "Field Maps" for Working for Workers
   Direction: a privacy-first cartographer's field instrument.
   Bold is spent in three places only: the title block, the
   marker system, and the survey readout. Everything else is quiet.
   ============================================================ */

@font-face{
  font-family:'Bricolage';src:url('../fonts/bricolage-400.woff2') format('woff2');
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Bricolage';src:url('../fonts/bricolage-600.woff2') format('woff2');
  font-weight:600;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Bricolage';src:url('../fonts/bricolage-800.woff2') format('woff2');
  font-weight:800;font-style:normal;font-display:swap;
}

:root{
  /* land-survey palette — no SaaS blue anywhere */
  --ink:#17150F;          /* warm near-black, instrument chrome   */
  --ink-2:#211E16;        /* raised surface                       */
  --ink-3:#2C281D;        /* inputs / wells                       */
  --paper:#EFEADD;        /* survey paper, primary text on dark   */
  --paper-dim:#B9B2A0;    /* secondary text                       */
  --slate:#857E6B;        /* muted / captions                     */
  --line:#39342889;       /* hairline on dark                     */
  --line-2:#46402F;       /* stronger divider                     */
  --pounamu:#3AA17F;      /* greenstone — primary action, routes  */
  --pounamu-d:#2E8B6F;
  --ochre:#D08434;        /* contour/topo — start, highlights     */
  --peg:#D2563E;          /* survey-peg red — destination, alert  */

  --display:'Bricolage',-apple-system,Segoe UI,Roboto,sans-serif;
  --body:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono","JetBrains Mono","IBM Plex Mono",Menlo,Consolas,monospace;

  --radius:10px;
  --panel-w:372px;
  --shadow:0 10px 34px rgba(0,0,0,.4);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:var(--body);color:var(--paper);background:var(--ink);-webkit-tap-highlight-color:transparent}
button{font-family:inherit;cursor:pointer;color:inherit}
::selection{background:var(--pounamu);color:var(--ink)}

#app{position:fixed;inset:0;display:flex}
.map{flex:1;height:100%;background:var(--ink)}

/* eyebrow / label treatment — structural, used everywhere a label is needed */
.eyebrow,.tab,.brand-text span,.r-dist,.pc-coords,.st-dist{
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;font-size:10.5px;
}

/* ---------------------------------------------------------- Panel ------- */
.panel{
  width:var(--panel-w);min-width:var(--panel-w);height:100%;background:var(--ink);
  display:flex;flex-direction:column;border-right:1px solid var(--line-2);z-index:5;
}

/* title block — like the margin block of a survey sheet */
.panel-head{padding:18px 18px 14px;border-bottom:1px solid var(--line-2)}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:30px;height:34px;flex:none}
.brand-mark path{fill:var(--paper)}
.brand-mark .pip{fill:var(--ochre)}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text strong{
  font-family:var(--display);font-weight:800;font-size:13px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--paper);
}
.brand-text span{color:var(--ochre);margin-top:5px;font-size:9.5px;letter-spacing:.34em}
.panel-head .only-mobile{position:absolute;top:14px;right:14px}

/* tabs as survey legend */
.tabs{display:flex;gap:0;padding:0 18px;border-bottom:1px solid var(--line-2)}
.tab{flex:1;border:0;background:none;padding:14px 4px 12px;color:var(--slate);
  border-bottom:2px solid transparent;transition:color .15s}
.tab:hover{color:var(--paper-dim)}
.tab.is-active{color:var(--pounamu);border-bottom-color:var(--pounamu)}

.tab-pane{display:none;flex:1;overflow-y:auto;padding:16px 18px;flex-direction:column;gap:14px}
.tab-pane.is-active{display:flex}
.tab-pane::-webkit-scrollbar{width:9px}
.tab-pane::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:9px}

/* ---------------------------------------------------------- search ------ */
.search-box{display:flex;align-items:center;gap:10px;background:var(--ink-3);
  border:1px solid var(--line-2);border-radius:var(--radius);padding:11px 13px}
.search-box:focus-within{border-color:var(--pounamu)}
.search-ico{color:var(--ochre);font-size:14px}
#searchInput{flex:1;border:0;background:none;font-size:15px;outline:none;color:var(--paper)}
#searchInput::placeholder{color:var(--slate)}
.icon-btn{border:0;background:none;font-size:15px;color:var(--slate);padding:4px;border-radius:8px}
.icon-btn:hover{background:var(--ink-2);color:var(--paper)}

.results{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.result{display:flex;gap:12px;align-items:flex-start;padding:11px 8px;border-radius:8px;
  cursor:pointer;border-bottom:1px solid var(--line)}
.result:last-child{border-bottom:0}
.result:hover{background:var(--ink-2)}
.result .r-ico{font-size:15px;margin-top:1px;filter:grayscale(.15)}
.result .r-main{font-size:14px;font-weight:600;line-height:1.3;color:var(--paper)}
.result .r-sub{font-size:12px;color:var(--paper-dim)}
.result .r-dist{margin-left:auto;color:var(--slate);white-space:nowrap}

.place-card{border:1px solid var(--line-2);border-radius:var(--radius);padding:14px;
  display:flex;flex-direction:column;gap:9px;background:var(--ink-2)}
.place-card h3{margin:0;font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:.01em}
.place-card .pc-sub{font-size:13px;color:var(--paper-dim)}
.place-card .pc-coords{color:var(--slate)}
.place-card .pc-actions{display:flex;gap:8px;flex-wrap:wrap}

.hint{font-size:12px;color:var(--slate);line-height:1.5;margin:2px 0 0}
.hint::before{content:"⌖ ";color:var(--ochre)}

/* ---------------------------------------------------------- directions -- */
.modes{display:flex;gap:7px}
.mode{flex:1;border:1px solid var(--line-2);background:var(--ink-2);border-radius:var(--radius);
  padding:11px 0;font-size:18px;filter:grayscale(.3);transition:.15s}
.mode:hover{border-color:var(--slate)}
.mode.is-active{border-color:var(--pounamu);background:#15281f;filter:none}
.waypoints{display:flex;flex-direction:column;gap:9px}
.wp{display:flex;align-items:center;gap:10px}
.wp .wp-dot{width:11px;height:11px;flex:none;border:2px solid}
.wp .wp-dot.start{border-radius:2px;background:var(--ochre);border-color:var(--ochre)} /* survey peg */
.wp .wp-dot.end{background:var(--peg);border-color:var(--peg);clip-path:polygon(50% 0,100% 100%,0 100%)} /* trig △ */
.wp .wp-dot.via{border-radius:50%;background:var(--pounamu);border-color:var(--pounamu)}
.wp input{flex:1;border:1px solid var(--line-2);background:var(--ink-3);border-radius:var(--radius);
  padding:10px 12px;font-size:14px;outline:none;color:var(--paper)}
.wp input::placeholder{color:var(--slate)}
.wp input:focus{border-color:var(--pounamu)}
.wp .wp-del{border:0;background:none;color:var(--slate);font-size:14px;padding:4px}
.wp .wp-del:hover{color:var(--peg)}
.wp-suggest{position:relative}
.wp-drop{position:absolute;top:calc(100% + 3px);left:0;right:0;background:var(--ink-2);
  border:1px solid var(--line-2);border-radius:var(--radius);box-shadow:var(--shadow);
  z-index:30;max-height:230px;overflow:auto}
.wp-drop .result{padding:9px}
.dir-actions{display:flex;justify-content:space-between}
.text-btn{border:0;background:none;color:var(--pounamu);font-family:var(--mono);
  text-transform:uppercase;letter-spacing:.1em;font-size:11px;padding:7px 4px}
.text-btn:hover{color:var(--paper)}
.primary-btn{border:0;background:var(--pounamu);color:#08120d;font-family:var(--display);
  font-weight:600;font-size:15px;letter-spacing:.02em;padding:13px;border-radius:var(--radius);width:100%}
.primary-btn:hover{background:var(--pounamu-d)}
.primary-btn:disabled{opacity:.45}

.route-summary{display:flex;align-items:baseline;gap:14px;padding:13px 15px;
  background:var(--ink-2);border:1px solid var(--line-2);border-left:3px solid var(--pounamu);border-radius:var(--radius)}
.route-summary .rs-time{font-family:var(--display);font-weight:800;font-size:24px;color:var(--paper)}
.route-summary .rs-dist{font-family:var(--mono);font-size:13px;color:var(--paper-dim)}
.route-summary .rs-note{margin-left:auto;font-family:var(--mono);text-transform:uppercase;
  letter-spacing:.1em;font-size:9.5px;color:var(--ochre);text-align:right}
.route-steps{list-style:none;margin:0;padding:0;counter-reset:s}
.route-steps li{display:flex;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line);
  font-size:13px;line-height:1.4;color:var(--paper-dim)}
.route-steps li::before{counter-increment:s;content:counter(s,decimal-leading-zero);flex:none;
  font-family:var(--mono);font-size:11px;color:var(--ochre);padding-top:1px}
.route-steps .st-dist{margin-left:auto;color:var(--slate);white-space:nowrap}

.panel-foot{display:flex;align-items:center;justify-content:space-between;padding:11px 18px;
  border-top:1px solid var(--line-2);font-family:var(--mono);font-size:10px;
  letter-spacing:.06em;color:var(--slate)}

/* ---------------------------------------------------------- map controls */
.fab-stack{position:absolute;right:14px;top:14px;display:flex;flex-direction:column;gap:8px;z-index:6}
.fab{width:44px;height:44px;border-radius:var(--radius);border:1px solid var(--line-2);
  background:var(--ink);color:var(--paper);box-shadow:var(--shadow);font-size:18px;
  display:grid;place-items:center;transition:.15s}
.fab:hover{border-color:var(--slate)}
.fab.is-active{background:#15281f;border-color:var(--pounamu);color:var(--pounamu)}

.open-panel{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:6;
  border:1px solid var(--line-2);background:var(--ink);color:var(--paper);box-shadow:var(--shadow);
  border-radius:24px;padding:12px 22px;font-family:var(--display);font-weight:600;font-size:15px}

/* --- SIGNATURE: the survey readout strip --- */
.readout{position:absolute;left:14px;bottom:14px;z-index:6;display:flex;align-items:stretch;
  background:rgba(23,21,15,.86);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--line-2);border-radius:var(--radius);overflow:hidden;
  font-family:var(--mono);box-shadow:var(--shadow);user-select:text}
.readout .ro-coords{padding:8px 13px;display:flex;flex-direction:column;gap:3px;line-height:1}
.readout .ro-latlng{font-size:13px;color:var(--paper);letter-spacing:.02em}
.readout .ro-meta{font-size:10px;color:var(--slate);letter-spacing:.08em}
.readout .ro-status{display:flex;align-items:center;gap:7px;padding:0 14px;
  border-left:1px solid var(--line-2);background:#15281f;color:var(--pounamu);
  font-size:9.5px;letter-spacing:.18em;text-transform:uppercase}
.readout .ro-dot{width:7px;height:7px;border-radius:50%;background:var(--pounamu);
  box-shadow:0 0 0 0 rgba(58,161,127,.7);animation:pulse 2.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(58,161,127,.6)}70%{box-shadow:0 0 0 7px rgba(58,161,127,0)}100%{box-shadow:0 0 0 0 rgba(58,161,127,0)}}

.toast{position:absolute;left:50%;bottom:78px;transform:translateX(-50%);background:var(--paper);
  color:var(--ink);padding:11px 17px;border-radius:var(--radius);font-size:13px;font-weight:600;
  z-index:20;box-shadow:var(--shadow)}

.dlg{border:1px solid var(--line-2);border-radius:14px;padding:24px;max-width:430px;
  background:var(--ink-2);color:var(--paper);box-shadow:var(--shadow)}
.dlg::backdrop{background:rgba(8,7,4,.66)}
.dlg h2{margin:0 0 12px;font-family:var(--display);font-weight:800;font-size:22px}
.dlg ul{padding-left:18px;font-size:14px;line-height:1.7;color:var(--paper-dim)}
.dlg ul strong{color:var(--paper)}
.dlg .fine{font-size:12px;color:var(--slate);line-height:1.6}

.only-mobile{display:none}

/* maplibre popups + controls themed dark */
.maplibregl-popup-content{background:var(--ink-2);color:var(--paper);border:1px solid var(--line-2);
  border-radius:var(--radius);padding:12px 14px;box-shadow:var(--shadow);font-size:13px}
.maplibregl-popup-tip{border-top-color:var(--ink-2)!important;border-bottom-color:var(--ink-2)!important}
.maplibregl-ctrl-group{background:var(--ink)!important;border:1px solid var(--line-2)!important;box-shadow:var(--shadow)!important}
.maplibregl-ctrl-group button+button{border-top:1px solid var(--line-2)!important}
.maplibregl-ctrl button .maplibregl-ctrl-icon{filter:invert(92%) sepia(8%) saturate(300%) hue-rotate(5deg)}
.maplibregl-ctrl-attrib{background:rgba(23,21,15,.8)!important;color:var(--slate)!important}
.maplibregl-ctrl-attrib a{color:var(--paper-dim)!important}
.maplibregl-ctrl-scale{background:rgba(23,21,15,.7)!important;border-color:var(--line-2)!important;color:var(--paper-dim)!important;font-family:var(--mono)}

/* ---------------------------------------------------------- mobile ------ */
@media (max-width:760px){
  #app{flex-direction:column}
  .panel{position:absolute;inset:auto 0 0 0;width:100%;min-width:0;height:74vh;border-right:0;
    border-radius:16px 16px 0 0;box-shadow:0 -10px 34px rgba(0,0,0,.5);
    transition:transform .25s ease;z-index:8}
  .panel.collapsed{transform:translateY(100%)}
  .map{height:100%}
  .only-mobile{display:inline-grid}
  .open-panel{display:block}
  .readout{bottom:auto;top:14px;left:14px;right:62px}
  .panel:not(.collapsed) ~ .open-panel{display:none}
}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
