@font-face{font-family:"Red Hat Display";src:url("rhd-var.woff2") format("woff2");font-weight:300 900;font-display:swap}
*{box-sizing:border-box;margin:0}
:root{
  --paper:#f4efe7; --surface:#fbf9f4; --card:#fff;
  --ink:#262420; --muted:#736d63; --faint:#9a9387; --line:#e7e0d4; --line2:#efe9df;
  --gold:#9a7b3f; --gold-deep:#765a2a; --gold-soft:#f0e6d2;
  --maroon:#7a2e36; --green:#2f7d50;
  --navy:#1f3a4d;
  --r:12px; --r-lg:18px;
  --sh:0 1px 2px rgba(40,30,15,.06),0 4px 14px rgba(40,30,15,.05);
  --sh-lg:0 10px 40px rgba(40,30,15,.16);
  --side-w:384px;
}
html,body{height:100%}
body{font-family:"Red Hat Display",system-ui,sans-serif;color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;overflow:hidden}

.app{display:grid;grid-template-columns:var(--side-w) 1fr;height:100vh;height:100dvh}

/* ============ sidebar ============ */
.side{display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--line);min-height:0;position:relative;z-index:30}
.brand{display:flex;align-items:center;gap:11px;padding:17px 20px 14px;text-decoration:none;color:var(--ink)}
.brand .cross{font-size:1.5rem;color:var(--gold);line-height:1;transform:translateY(-1px)}
.brand-tx{display:flex;flex-direction:column;line-height:1.15}
.brand-tx b{font-size:1.18rem;font-weight:800;letter-spacing:-.3px}
.brand-tx small{font-size:.76rem;color:var(--muted);font-weight:500}

.tabs{display:flex;padding:0 14px;gap:4px;border-bottom:1px solid var(--line)}
.tab{flex:1;background:none;border:none;font-family:inherit;font-size:.94rem;font-weight:700;color:var(--faint);
  padding:11px 8px 13px;cursor:pointer;position:relative;letter-spacing:-.2px}
.tab i{font-style:normal;font-size:.74rem;font-weight:700;color:var(--gold);background:var(--gold-soft);
  padding:1px 7px;border-radius:20px;margin-left:3px;vertical-align:1px}
.tab.is-active{color:var(--ink)}
.tab.is-active::after{content:"";position:absolute;left:8px;right:8px;bottom:-1px;height:2.5px;background:var(--gold);border-radius:3px}

.panel{flex:1;display:flex;flex-direction:column;min-height:0}
.panel.is-hidden{display:none}
.controls{padding:14px 16px 10px;border-bottom:1px solid var(--line2);flex-shrink:0}
.search-wrap{position:relative;margin-bottom:11px}
.search-ic{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--faint)}
.search-wrap input{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:10px 12px 10px 36px;
  font-family:inherit;font-size:.9rem;background:#fff;color:var(--ink)}
.search-wrap input:focus{outline:none;border-color:var(--gold)}
.filter-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--faint);margin:4px 0 7px}

.chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:6px}
.chip{border:1.5px solid var(--line);background:#fff;border-radius:30px;padding:5px 12px 5px 9px;
  font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;color:var(--ink);
  display:inline-flex;align-items:center;gap:7px;transition:.13s;white-space:nowrap}
.chip .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.chip .n{color:var(--faint);font-weight:500;font-size:.76rem}
.chip:hover{border-color:var(--gold)}
.chip.is-on{color:#fff;border-color:transparent}
.chip.is-on .dot{box-shadow:0 0 0 2px rgba(255,255,255,.6)}
.chip.is-on .n{color:rgba(255,255,255,.8)}
.clear-link{font-size:.76rem;color:var(--gold-deep);background:none;border:none;cursor:pointer;font-family:inherit;
  font-weight:700;padding:4px 2px;text-decoration:underline}

/* ============ list ============ */
.list{flex:1;overflow-y:auto;padding:8px 12px 14px;scrollbar-width:thin}
.list-empty{color:var(--muted);font-size:.88rem;text-align:center;padding:36px 20px;line-height:1.5}
.lcard{display:flex;gap:11px;padding:11px;border-radius:var(--r);cursor:pointer;border:1px solid transparent;transition:.12s}
.lcard:hover{background:#fff;border-color:var(--line2);box-shadow:var(--sh)}
.lcard.is-sel{background:#fff;border-color:var(--gold);box-shadow:var(--sh)}
.lcard-thumb{width:54px;height:54px;border-radius:10px;flex-shrink:0;object-fit:cover;background:var(--gold-soft);
  display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.3rem}
.lcard-body{min-width:0;flex:1}
.lcard-name{font-size:.93rem;font-weight:700;line-height:1.2;margin-bottom:3px}
.lcard-meta{font-size:.8rem;color:var(--muted);line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tag{display:inline-block;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.4px;
  padding:2px 7px;border-radius:5px;color:#fff;vertical-align:1px}

/* event card */
.ecard{display:flex;gap:12px;padding:11px;border-radius:var(--r);cursor:pointer;border:1px solid transparent;transition:.12s}
.ecard:hover{background:#fff;border-color:var(--line2);box-shadow:var(--sh)}
.ecard.is-sel{background:#fff;border-color:var(--gold);box-shadow:var(--sh)}
.edate{flex-shrink:0;width:50px;text-align:center;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:#fff;align-self:flex-start}
.edate .m{background:var(--maroon);color:#fff;font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;padding:2px 0}
.edate .d{font-size:1.25rem;font-weight:800;line-height:1.5;color:var(--ink)}
.ecard-body{min-width:0;flex:1}
.ecard-title{font-size:.93rem;font-weight:700;line-height:1.2;margin-bottom:3px}
.ecard-meta{font-size:.8rem;color:var(--muted);line-height:1.4}
.ecard-when{font-size:.78rem;color:var(--gold-deep);font-weight:700}

.side-foot{padding:12px 16px;border-top:1px solid var(--line);flex-shrink:0;background:var(--surface)}
.foot-link{display:block;text-align:center;margin-top:9px;font-size:.76rem;color:var(--faint);text-decoration:none}
.foot-link:hover{color:var(--gold-deep)}

/* ============ buttons ============ */
.btn{border:none;border-radius:10px;padding:10px 16px;font-family:inherit;font-weight:700;font-size:.9rem;
  cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:.13s}
.btn.primary{background:var(--gold);color:#fff}
.btn.primary:hover{background:var(--gold-deep)}
.btn.ghost{background:#fff;border:1.5px solid var(--line);color:var(--ink)}
.btn.ghost:hover{border-color:var(--gold)}
.btn.sm{padding:7px 12px;font-size:.82rem}
.btn.block{width:100%}
.btn[disabled]{opacity:.55;cursor:default}

/* ============ map ============ */
.map-wrap{position:relative;min-height:0}
#map{position:absolute;inset:0}
.maplibregl-ctrl-group{box-shadow:var(--sh)!important;border-radius:10px!important}

/* detail card */
.detail{position:absolute;left:16px;bottom:16px;width:340px;max-width:calc(100% - 32px);background:var(--card);
  border-radius:var(--r-lg);box-shadow:var(--sh-lg);overflow:hidden;opacity:0;transform:translateY(12px);
  pointer-events:none;transition:.2s;z-index:12;max-height:calc(100% - 32px);display:flex;flex-direction:column}
.detail.is-open{opacity:1;transform:none;pointer-events:auto}
.detail-photo{width:100%;height:148px;object-fit:cover;background:var(--gold-soft);flex-shrink:0}
.detail-x{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;border:none;
  background:rgba(255,255,255,.92);color:var(--ink);font-size:15px;cursor:pointer;box-shadow:var(--sh);z-index:2}
.detail-body{flex:1;min-height:0;padding:15px 17px 17px;overflow-y:auto}
.detail.no-photo .detail-body{padding-top:40px}
.detail-tag{margin-bottom:7px}
.detail h3{font-size:1.18rem;font-weight:800;line-height:1.18;margin-bottom:9px}
.drow{display:flex;gap:9px;font-size:.86rem;color:var(--muted);margin:6px 0;line-height:1.4;align-items:flex-start}
.drow svg{flex-shrink:0;color:var(--gold);margin-top:2px}
.drow a{color:var(--gold-deep);text-decoration:none;font-weight:600;word-break:break-word}
.drow a:hover{text-decoration:underline}
.detail-when{background:var(--gold-soft);color:var(--gold-deep);font-weight:700;font-size:.86rem;
  padding:8px 11px;border-radius:9px;margin-bottom:10px}

/* ============ modal ============ */
.modal-bg{position:fixed;inset:0;background:rgba(28,20,8,.5);display:none;align-items:flex-start;justify-content:center;
  z-index:50;overflow-y:auto;padding:28px 16px}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);width:100%;max-width:500px;padding:26px;box-shadow:var(--sh-lg);position:relative}
.modal .x{position:absolute;top:16px;right:16px;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);
  background:#fff;color:var(--muted);font-size:14px;cursor:pointer}
.modal h2{font-size:1.35rem;font-weight:800;margin-bottom:4px}
.modal .sub{color:var(--muted);font-size:.88rem;margin-bottom:14px;line-height:1.45}
.modal label{display:block;font-size:.78rem;font-weight:700;color:var(--muted);margin:13px 0 5px}
.modal input,.modal select,.modal textarea{width:100%;border:1.5px solid var(--line);border-radius:9px;
  padding:9px 11px;font-family:inherit;font-size:.9rem;background:#fff;color:var(--ink);resize:vertical}
.modal input:focus,.modal select:focus,.modal textarea:focus{outline:none;border-color:var(--gold)}
.two{display:flex;gap:12px}.two>div{flex:1;min-width:0}
.geo-row{display:flex;gap:8px}.geo-row input{flex:1}
.loc-hint{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:7px}
.loc-state{font-size:.78rem;color:var(--muted)}
.loc-ok{color:var(--green);font-weight:700}
.modal-err{color:var(--maroon);font-size:.84rem;margin-top:11px;min-height:1em}
.modal .btn.block{margin-top:16px}
.modal-done{text-align:center;padding:14px 0}
.modal-done .big{font-size:2.4rem}
.modal-done h2{margin:6px 0}

/* upload widget */
.upl{cursor:pointer}
.upl-box{border:1.5px dashed var(--line);border-radius:10px;padding:16px;text-align:center;font-size:.85rem;
  font-weight:600;color:var(--muted);background:var(--surface);transition:.13s}
.upl:hover .upl-box{border-color:var(--gold);color:var(--gold-deep)}
.upl.has-img .upl-box{padding:0;border-style:solid;overflow:hidden;background:none}
.upl.has-img .upl-box img{width:100%;height:130px;object-fit:cover;display:block}
.upl.busy .upl-box{color:var(--gold-deep)}

/* pick banner */
#pick-banner{display:none;position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:60;
  background:var(--ink);color:#fff;padding:9px 9px 9px 16px;border-radius:11px;box-shadow:var(--sh-lg);
  align-items:center;gap:12px;font-size:.88rem;font-weight:600;max-width:92vw}
#pick-banner.on{display:flex}
#pick-banner .btn.ghost{background:transparent;border-color:rgba(255,255,255,.4);color:#fff}

/* ============ responsive (bottom-sheet mobile) ============ */
.sheet-grip{display:none}
.fab{display:none}

@media (max-width:860px){
  .app{display:block;position:relative;height:100vh;height:100dvh}
  .map-wrap{position:absolute;inset:0}

  /* sidebar -> draggable bottom sheet over a full-bleed map */
  .side{
    position:absolute;left:0;right:0;bottom:0;top:auto;width:auto;
    height:92vh;height:92dvh;max-height:92vh;max-height:92dvh;
    border-right:none;border-top:1px solid var(--line);
    border-radius:22px 22px 0 0;box-shadow:0 -10px 44px rgba(40,30,15,.22);
    transform:translateY(44vh);transform:translateY(44dvh);
    transition:transform .32s cubic-bezier(.32,.72,0,1);z-index:30;
    overscroll-behavior:contain;will-change:transform;
  }
  .side.dragging{transition:none}
  .sheet-grip{display:block;flex-shrink:0;padding:10px 0 2px;touch-action:none;cursor:grab}
  .sheet-grip::before{content:"";display:block;width:40px;height:5px;border-radius:3px;background:#d8d0c2;margin:0 auto}
  .brand{padding:4px 18px 8px}
  .brand .cross{font-size:1.3rem}
  .brand-tx b{font-size:1.06rem}
  .brand-tx small{display:none}
  .side-foot{display:none}
  .list{padding-bottom:calc(20px + env(safe-area-inset-bottom))}
  .chip{padding:8px 13px 8px 10px}
  .search-wrap input{padding-top:12px;padding-bottom:12px}

  /* detail -> bottom sheet (z-index above the list sheet so the descending list
     never overpaints the rising detail; height matches the flyTo reserve) */
  .detail{left:0;right:0;bottom:0;width:auto;max-width:none;border-radius:22px 22px 0 0;z-index:31;
    max-height:56vh;max-height:56dvh;box-shadow:0 -10px 44px rgba(40,30,15,.22);transform:translateY(101%);
    padding-bottom:env(safe-area-inset-bottom)}
  .detail.is-open{transform:none}
  .detail-photo{height:150px}
  .detail-grip{display:block;padding:9px 0 0;touch-action:none}
  .detail-grip::before{content:"";display:block;width:40px;height:5px;border-radius:3px;background:#d8d0c2;margin:0 auto}
  .detail-x{top:8px;right:12px}

  /* floating action button */
  .fab{display:flex;position:fixed;right:16px;bottom:calc(18px + env(safe-area-inset-bottom));z-index:38;
    width:56px;height:56px;border-radius:50%;border:none;background:var(--gold);color:#fff;
    font-size:2rem;font-weight:300;line-height:1;align-items:center;justify-content:center;
    box-shadow:0 6px 22px rgba(122,90,42,.5);cursor:pointer;transition:transform .12s,opacity .15s}
  .fab:active{transform:scale(.93)}
  body.detail-open .fab,body.modal-open .fab,body.picking-m .fab{opacity:0;pointer-events:none}

  /* submit modals -> full-width sheets sliding from the bottom */
  .modal-bg{align-items:flex-end;padding:0}
  .modal{max-width:none;border-radius:22px 22px 0 0;max-height:94vh;max-height:94dvh;overflow-y:auto;
    padding:24px 20px calc(26px + env(safe-area-inset-bottom));
    animation:sheetUp .28s cubic-bezier(.32,.72,0,1)}
  @keyframes sheetUp{from{transform:translateY(40px)}to{transform:none}}

  #pick-banner{top:auto;bottom:calc(16px + env(safe-area-inset-bottom));font-size:.84rem}
}
.detail-grip{display:none}
.list::-webkit-scrollbar,.detail-body::-webkit-scrollbar{width:8px}
.list::-webkit-scrollbar-thumb,.detail-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
