* { margin:0; padding:0; box-sizing:border-box; }

:root {
  --sidebar: 380px;
  --bg: #f4f4f4;
  --white: #fff;
  --text: #1a1a1a;
  --muted: #777;
  --border: #e2e2e2;
  --accent: #d97726;
  --sh: 0 1px 4px rgba(0,0,0,0.08);
  --sh2: 0 4px 12px rgba(0,0,0,0.13);
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  height:100vh; overflow:hidden;
  background:var(--bg); color:var(--text);
}

.app { display:flex; height:100vh; }

/* ── Sidebar ─────────────────────────────────── */
.sidebar {
  width:var(--sidebar); min-width:120px;
  background:var(--white);
  display:flex; flex-direction:column;
  border-right:1px solid var(--border);
  overflow:hidden;
}
.sidebar-header {
  padding:14px 16px 10px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding-top: calc(14px + env(safe-area-inset-top));
}
.sidebar-header-text h1 { font-size:17px; font-weight:700; letter-spacing:-.3px; }
.sidebar-header-text .sub { font-size:11px; color:var(--muted); margin-top:2px; }
.add-btn {
  width:36px; height:36px; border-radius:50%; border:none;
  background:var(--accent); color:#fff; font-size:24px; line-height:1;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:opacity .15s;
}
.add-btn:hover { opacity:.85; }
.gear-btn {
  width:36px; height:36px; border-radius:50%; border:1.5px solid var(--border);
  background:transparent; font-size:18px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:all .15s; position:relative;
}
.gear-btn:hover { background:#f0f0f0; }
.gear-menu {
  display:none; position:absolute; top:calc(100% + 8px); right:0;
  background:#fff; border:1px solid var(--border); border-radius:12px;
  box-shadow:var(--sh2); z-index:300; min-width:180px; overflow:hidden;
}
.gear-menu.open { display:block; }
.gear-menu-item {
  padding:12px 16px; display:flex; align-items:center; justify-content:space-between;
  font-size:13px; border-bottom:1px solid var(--border); gap:12px;
}
.gear-menu-item:last-child { border-bottom:none; }
.gear-menu-item a {
  color:var(--text); text-decoration:none; font-size:13px;
  display:flex; align-items:center; gap:8px; width:100%;
}
.gear-menu-item a:hover { color:var(--accent); }

/* ── Toolbar row ─────────────────────────────── */
.toolbar {
  padding:8px 10px;
  border-bottom:1px solid var(--border);
  background:var(--white);
  display:flex; align-items:center; gap:6px;
}
.toolbar-btn {
  padding:5px 11px; border-radius:7px; border:1.5px solid var(--border);
  background:transparent; font-size:12px; cursor:pointer;
  font-family:inherit; white-space:nowrap; transition:all .15s;
  display:flex; align-items:center; gap:4px;
}
.toolbar-btn:hover { background:#f0f0f0; }
.toolbar-btn.primary { background:var(--accent); color:#fff; border-color:var(--accent); }
.toolbar-btn.primary:hover { opacity:.88; }
.toolbar-btn.icon-btn { padding:5px 8px; }

/* Save status indicator */
#save-status {
  font-size:11px; color:var(--muted); margin-left:2px;
  white-space:nowrap; transition:color .2s;
}
#save-status.saving { color:var(--accent); }
#save-status.saved  { color:#22c55e; }
#save-status.error  { color:#c0392b; }

/* ── Track Map toggle ────────────────────────── */
.switch { position:relative; display:inline-block; width:40px; height:22px; flex-shrink:0; }
.switch input { opacity:0; width:0; height:0; }
.slider {
  position:absolute; cursor:pointer;
  top:0; left:0; right:0; bottom:0;
  background:#ccc; transition:.3s; border-radius:22px;
}
.slider:before {
  position:absolute; content:"";
  height:16px; width:16px; left:3px; bottom:3px;
  background:white; transition:.3s; border-radius:50%;
}
input:checked + .slider { background:var(--accent); }
input:checked + .slider:before { transform:translateX(18px); }
.track-wrap { display:flex; align-items:center; gap:5px; margin-left:auto; }
.track-label { font-size:11px; color:var(--muted); }



/* ── Filters ─────────────────────────────────── */
.filters {
  padding:8px 10px; display:flex; flex-wrap:wrap; gap:5px;
  border-bottom:1px solid var(--border); background:var(--white);
}
.fbtn {
  padding:3px 10px; border-radius:20px; border:1.5px solid var(--border);
  background:transparent; font-size:11.5px; cursor:pointer;
  transition:all .15s; white-space:nowrap; font-family:inherit;
}
.fbtn:hover { opacity:.8; background:#f0f0f0; }
.fbtn.on { color:#fff !important; font-weight:600; }
.pcount { font-size:10px; opacity:.7; margin-left:2px; }

/* ── Tag filters ─────────────────────────────── */
.tag-filters {
  padding:6px 10px; display:flex; flex-wrap:wrap; gap:5px;
  border-bottom:1px solid var(--border); background:#fafafa;
}
.tag-filters:empty { display:none; }
.tbtn-wrap { display:flex; border-radius:20px; overflow:hidden; border:1.5px solid #bbb; }
.tbtn {
  padding:2px 9px; font-size:11px; cursor:pointer; font-family:inherit;
  background:transparent; border:none; transition:all .15s; white-space:nowrap;
  color:#555;
}
.tbtn:hover { background:#eee; }
.tbtn.on  { background:#555; color:#fff; font-weight:600; }
.tbtn.off { background:#c0392b; color:#fff; font-weight:600; }
.tbtn-excl { border-left:1px solid #bbb; font-size:10px; padding:2px 7px; }

/* Tag chips on cards / detail */
.card-tags { display:flex; flex-wrap:wrap; gap:3px; margin-top:4px; }
.tag-chip {
  font-size:10px; padding:1px 7px; border-radius:10px;
  background:#f0f0f0; color:#555; font-weight:500;
}

/* Tag picker in form */
.tag-picker { display:flex; flex-wrap:wrap; gap:5px; margin-top:6px; }
.tag-pick-btn {
  padding:2px 10px; border-radius:20px; border:1.5px solid var(--border);
  background:transparent; font-size:11.5px; cursor:pointer;
  font-family:inherit; transition:all .15s;
}
.tag-pick-btn.selected { background:#555; border-color:#555; color:#fff; font-weight:600; }
.tag-pick-btn:hover { background:#f0f0f0; }
.tag-pick-btn.selected:hover { background:#333; }

/* ── Gallery ─────────────────────────────────── */
.gallery { flex:1; overflow-y:auto; padding:8px; background:var(--bg); }
.gallery::-webkit-scrollbar { width:5px; }
.gallery::-webkit-scrollbar-thumb { background:#ccc; border-radius:3px; }

.flabel {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:1px; color:var(--muted); padding:10px 6px 4px;
}

/* ── List card ───────────────────────────────── */
.card {
  background:var(--white); border-radius:10px; margin-bottom:7px;
  cursor:pointer; transition:all .15s;
  border:2px solid transparent; box-shadow:var(--sh); position:relative;
  display:flex; align-items:stretch; overflow:hidden; min-height:64px;
}
.card:hover { box-shadow:var(--sh2); transform:translateX(2px); }
.card.on {
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(217,119,38,.12), var(--sh2);
}
.card-body { padding:9px 12px 9px; flex:1; min-width:0; }
.card-tag {
  display:inline-block; font-size:10px; font-weight:600;
  text-transform:uppercase; letter-spacing:.4px;
  padding:1px 6px; border-radius:4px; margin-bottom:3px;
}
.card-name { font-size:13px; font-weight:600; line-height:1.3; margin-bottom:2px; }
.card-desc {
  font-size:11.5px; color:var(--muted); line-height:1.4;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; line-clamp:2; overflow:hidden;
}
.card-thumb {
  width:83px; min-width:83px;
  object-fit:cover; display:block; background:#eee; align-self:stretch;
}

.card-actions { position:absolute; top:4px; right:4px; display:none; gap:4px; }
.card:hover .card-actions { display:flex; }
.card-action-btn {
  padding:3px 7px; border-radius:5px; border:none;
  font-size:11px; cursor:pointer; font-family:inherit; backdrop-filter:blur(4px);
}
.card-action-btn.edit { background:rgba(255,255,255,.9); color:var(--text); }
.card-action-btn.del  { background:rgba(192,57,43,.85); color:#fff; }
.card-action-btn:hover { opacity:.85; }

/* ── Detail view ─────────────────────────────── */
.detail {
  flex:1; overflow-y:auto; background:var(--white); display:none; flex-direction:column;
}
.detail.open { display:flex; }
.detail::-webkit-scrollbar { width:5px; }
.detail::-webkit-scrollbar-thumb { background:#ccc; border-radius:3px; }

.detail-back {
  padding:10px 14px; border-bottom:1px solid var(--border);
  background:var(--white); display:flex; align-items:center; gap:8px;
  cursor:pointer; font-size:13px; font-weight:600; color:var(--text);
  flex-shrink:0;
}
.detail-back:hover { background:#f5f5f5; }
.detail-back-arrow { font-size:16px; line-height:1; }

.detail-img { width:100%; max-height:240px; object-fit:cover; display:block; }
.detail-video { width:100%; aspect-ratio:16/9; display:block; border:none; }
.detail-body { padding:16px; background:var(--white); flex:1; }
.detail-tag {
  display:inline-block; font-size:10px; font-weight:600;
  text-transform:uppercase; letter-spacing:.4px;
  padding:2px 7px; border-radius:4px; margin-bottom:8px;
}
.detail-name { font-size:17px; font-weight:700; line-height:1.3; margin-bottom:10px; }
.detail-desc { font-size:13px; color:var(--muted); line-height:1.7; white-space:pre-wrap; }
.detail-link { margin-top:14px; }
.detail-link a {
  color:var(--accent); font-size:13px; font-weight:600; text-decoration:none;
}
.detail-link a:hover { text-decoration:underline; }
.detail-actions { padding:12px 16px; display:flex; gap:8px; background:var(--white); flex-shrink:0; }
.detail-actions button {
  padding:7px 16px; border-radius:8px; border:1.5px solid var(--border);
  font-size:12px; cursor:pointer; font-family:inherit; background:var(--white);
}
.detail-actions button:hover { background:#f0f0f0; }
.detail-actions .det-del { color:#c0392b; border-color:#c0392b44; }
.detail-actions .det-del:hover { background:#fff0f0; }
.detail-actions .det-go { color:#0a7c42; border-color:#0a7c4244; text-decoration:none; display:inline-flex; align-items:center; gap:5px; padding:7px 16px; border-radius:8px; border:1.5px solid #0a7c4244; font-size:12px; font-family:inherit; background:var(--white); }
.detail-actions .det-go:hover { background:#f0fff7; }

/* ── Map ─────────────────────────────────────── */
.map-wrap { flex:1; position:relative; }
#map { width:100%; height:100%; }

/* ── Custom marker pin ───────────────────────── */
.gpin {
  position:relative; width:30px; height:38px;
  cursor:pointer; transition:transform .15s, filter .15s;
  transform-origin: bottom center;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.4));
}
.gpin svg { width:30px; height:38px; display:block; }
.gpin:hover, .gpin.hovered {
  transform: scale(1.4) translateY(-3px);
  filter: drop-shadow(0 5px 8px rgba(0,0,0,.45));
}
.gpin.active {
  transform: scale(1.5) translateY(-4px);
  filter: drop-shadow(0 6px 10px rgba(0,0,0,.5));
}
.gpin-pulse {
  position:absolute; bottom:-4px; left:50%;
  transform:translateX(-50%); width:20px; height:20px;
  border-radius:50%; opacity:0;
}
.gpin.active .gpin-pulse { animation:gpulse 1.4s ease-out infinite; }
@keyframes gpulse {
  0%   { transform:translateX(-50%) scale(.4); opacity:.9; }
  100% { transform:translateX(-50%) scale(3);  opacity:0; }
}

/* ── My location ─────────────────────────────── */
.map-loc-btn {
  width:40px; height:40px; border-radius:8px; border:none;
  background:#fff; box-shadow:0 2px 6px rgba(0,0,0,.2);
  font-size:20px; cursor:pointer; margin:8px;
  display:flex; align-items:center; justify-content:center;
  color:#1a73e8;
}
.map-loc-btn:hover { background:#f0f6ff; }
.my-location-dot {
  width:18px; height:18px; border-radius:50%;
  background:#1a73e8; border:3px solid #fff;
  box-shadow:0 0 0 2px rgba(26,115,232,.4), 0 2px 6px rgba(0,0,0,.3);
}

/* ── Google Maps info window ─────────────────── */
.gm-style .gm-style-iw-c {
  border-radius:14px !important; box-shadow:0 8px 24px rgba(0,0,0,.18) !important;
  padding:0 !important; overflow:hidden !important;
}
.gm-style .gm-style-iw-d { overflow:hidden !important; padding:0 !important; }
.gm-style .gm-style-iw-t::after { display:none; }
.gm-style .gm-style-iw-chr { display:none !important; }
.add-popup {
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  padding:14px 16px; min-width:200px; max-width:280px;
}
.add-popup-header {
  display:flex; align-items:flex-start; gap:8px; margin-bottom:12px;
}
.add-popup-name {
  font-size:15px; font-weight:700; color:#1a1a1a; line-height:1.3; flex:1;
}
.add-popup-close {
  background:none; border:none; font-size:14px; color:#aaa;
  cursor:pointer; padding:0; line-height:1; flex-shrink:0; margin-top:1px;
}
.add-popup-close:hover { color:#555; }
.add-popup-btn {
  width:100%; padding:10px; background:#d97726; color:#fff;
  border:none; border-radius:10px; font-size:14px; font-weight:600;
  cursor:pointer; font-family:inherit; letter-spacing:.1px;
}
.iw-wrap { padding:14px 16px; font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif; min-width:200px; max-width:260px; }
.iw-cat { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; margin-bottom:3px; }
.iw-name { font-size:14px; font-weight:700; color:#1a1a1a; margin-bottom:8px; line-height:1.3; }
.iw-img { width:100%; height:110px; object-fit:cover; border-radius:7px; margin-bottom:8px; display:block; }
.iw-desc { font-size:12px; color:#777; line-height:1.5; max-height:60px; overflow:hidden; }
.iw-actions { margin-top:10px; display:flex; gap:6px; align-items:center; }
.iw-details-btn { flex:1; padding:7px 0; background:#1a1a1a; color:#fff; border:none; border-radius:7px; font-size:13px; font-weight:600; cursor:pointer; font-family:inherit; }
.iw-details-btn:active { background:#444; }
.iw-close-btn { padding:7px 10px; background:none; border:1.5px solid #ddd; border-radius:7px; font-size:13px; color:#888; cursor:pointer; line-height:1; }
.iw-close-btn:active { background:#f0f0f0; }

/* ── Modal base ──────────────────────────────── */
.modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.45);
  z-index:1000; display:none; align-items:center; justify-content:center;
}
.modal-overlay.open { display:flex; }
.modal {
  background:#fff; border-radius:14px; padding:24px 22px;
  width:460px; max-width:96vw; max-height:92vh; overflow-y:auto;
  box-shadow:0 12px 40px rgba(0,0,0,.22);
}
.modal h2 { font-size:16px; font-weight:700; margin-bottom:16px; }
.form-row { margin-bottom:13px; }
.form-row label { display:block; font-size:12px; font-weight:600; margin-bottom:4px; color:var(--muted); }
.form-row input, .form-row select, .form-row textarea {
  width:100%; padding:8px 10px; border:1.5px solid var(--border);
  border-radius:8px; font-size:13px; font-family:inherit; outline:none; transition:border-color .15s;
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus { border-color:var(--accent); }
.form-row textarea { resize:vertical; min-height:70px; }
.form-coords { display:flex; gap:8px; }
.form-coords input { flex:1; }
.coord-hint { font-size:11px; color:var(--muted); margin-top:4px; }
.modal-actions { display:flex; gap:8px; margin-top:18px; justify-content:flex-end; }
.modal-actions button { padding:8px 18px; border-radius:8px; border:none; font-size:13px; font-family:inherit; cursor:pointer; }
.btn-save { background:var(--accent); color:#fff; font-weight:600; }
.btn-save:hover { opacity:.88; }
.btn-cancel { background:var(--bg); color:var(--text); }
.btn-cancel:hover { background:#e8e8e8; }

/* ── Block editor ────────────────────────────── */
.blocks-editor { display:flex; flex-direction:column; gap:8px; margin-top:4px; }
.block-item {
  border:1.5px solid var(--border); border-radius:10px;
  overflow:hidden; background:#fff; position:relative;
}
.block-toolbar {
  display:flex; align-items:center; gap:4px;
  padding:5px 8px; background:#fafafa; border-bottom:1px solid var(--border);
}
.block-type-label { font-size:10px; font-weight:700; text-transform:uppercase; color:var(--muted); letter-spacing:.5px; flex:1; }
.block-move-btn, .block-del-btn {
  border:none; background:none; cursor:pointer; font-size:14px; padding:2px 5px; border-radius:4px;
}
.block-move-btn:hover { background:#eee; }
.block-del-btn { color:#c0392b; }
.block-del-btn:hover { background:#fff0f0; }
.block-text-input {
  width:100%; padding:9px 10px; border:none; font-size:13px;
  font-family:inherit; resize:vertical; min-height:70px; outline:none;
  background:#fff;
}
.block-img-preview {
  width:100%; max-height:180px; object-fit:cover; display:block;
}
.block-video-preview { width:100%; aspect-ratio:16/9; border:none; display:block; }
.block-upload-area {
  padding:16px; display:flex; flex-direction:column; align-items:center; gap:8px;
  background:#fafafa; cursor:pointer;
}
.block-upload-area input[type=file] { display:none; }
.block-upload-hint { font-size:12px; color:var(--muted); text-align:center; }
.block-upload-progress { font-size:11px; color:var(--muted); }
.blocks-add-row { display:flex; gap:6px; flex-wrap:wrap; margin-top:4px; }
.block-add-btn {
  padding:6px 12px; border-radius:8px; border:1.5px dashed var(--border);
  background:transparent; font-size:12px; cursor:pointer; font-family:inherit;
  color:var(--muted); transition:all .15s;
}
.block-add-btn:hover { border-color:var(--accent); color:var(--accent); background:#fff8f0; }

/* ── Detail blocks ────────────────────────────── */
.detail-block-text { padding:0 16px 14px; font-size:13px; color:var(--muted); line-height:1.7; white-space:pre-wrap; }
.detail-block-text:first-child { padding-top:14px; }
.detail-block-img { width:100%; display:block; }
.detail-block-video { width:100%; aspect-ratio:16/9; border:none; display:block; }

/* ── Image upload row ────────────────────────── */
.upload-row { display:flex; gap:6px; align-items:center; margin-top:5px; }
.upload-row input[type=file] { display:none; }
.upload-btn {
  padding:5px 10px; border-radius:7px; border:1.5px solid var(--border);
  background:var(--bg); font-size:12px; cursor:pointer; font-family:inherit;
  white-space:nowrap; flex-shrink:0;
}
.upload-btn:hover { background:#e8e8e8; }
.upload-progress { font-size:11px; color:var(--muted); }

/* ── Password gate ───────────────────────────── */
#pw-gate {
  position:fixed; inset:0; background:var(--bg);
  z-index:2000; display:flex; align-items:center; justify-content:center;
}
.pw-box {
  background:#fff; border-radius:16px; padding:36px 32px;
  width:340px; max-width:94vw; box-shadow:0 8px 32px rgba(0,0,0,.12);
  text-align:center;
}
.pw-box h1 { font-size:20px; font-weight:700; margin-bottom:6px; }
.pw-box p  { font-size:13px; color:var(--muted); margin-bottom:22px; }
.pw-box input {
  width:100%; padding:10px 14px; border:1.5px solid var(--border);
  border-radius:9px; font-size:15px; font-family:inherit;
  outline:none; text-align:center; letter-spacing:2px; margin-bottom:12px;
  transition:border-color .15s;
}
.pw-box input:focus { border-color:var(--accent); }
.pw-box button {
  width:100%; padding:10px; background:var(--accent); color:#fff;
  border:none; border-radius:9px; font-size:14px; font-weight:600;
  font-family:inherit; cursor:pointer;
}
.pw-box button:hover { opacity:.88; }
.pw-error { color:#c0392b; font-size:12px; margin-top:8px; min-height:16px; }

/* ── Settings modal ──────────────────────────── */
.settings-grid { display:flex; flex-direction:column; gap:12px; }
.settings-note { font-size:11.5px; color:var(--muted); line-height:1.6; background:var(--bg); padding:10px 12px; border-radius:8px; }
.settings-note a { color:var(--accent); }

/* ── Loading / Error ─────────────────────────── */
.loading { display:flex; align-items:center; justify-content:center; height:100%; flex-direction:column; gap:12px; }
.spinner { width:28px; height:28px; border:3px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:spin .8s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }
.loading-txt { font-size:13px; color:var(--muted); }
.err { padding:20px; text-align:center; color:#c0392b; font-size:13px; line-height:1.6; }

/* ── Place search view ───────────────────────── */
.place-search-view {
  display:none; flex-direction:column; flex:1; overflow:hidden;
}
.place-search-view.open { display:flex; }
.place-search-bar {
  padding:10px 12px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:8px; background:var(--white);
}
.place-search-bar input {
  flex:1; padding:9px 12px; border:1.5px solid var(--border);
  border-radius:8px; font-size:16px; font-family:inherit;
  outline:none; transition:border-color .15s; background:var(--bg);
}
.place-search-bar input:focus { border-color:var(--accent); background:#fff; }
.place-search-cancel {
  background:none; border:none; font-size:14px; color:var(--muted);
  cursor:pointer; font-family:inherit; padding:4px 6px; flex-shrink:0;
}
.place-search-results { flex:1; overflow-y:auto; background:var(--bg); }
.psr-item {
  padding:13px 16px; border-bottom:1px solid var(--border); background:#fff;
  cursor:pointer; display:flex; flex-direction:column; gap:2px; margin-bottom:1px;
}
.psr-item:hover { background:#f5f5f5; }
.psr-item strong { font-size:14px; color:var(--text); }
.psr-item small  { font-size:12px; color:var(--muted); }
.psr-empty { padding:24px 16px; text-align:center; font-size:13px; color:var(--muted); }

/* ── Resizer ─────────────────────────────────── */
.resizer {
  background:var(--border); flex-shrink:0; position:relative; z-index:10;
  display:flex; align-items:center; justify-content:center;
  transition:background .15s;
}
.resizer:hover, .resizer.dragging { background:var(--accent); }
.resizer-handle {
  background:#aaa; border-radius:3px; pointer-events:none;
}
/* desktop: vertical resizer */
@media(min-width:769px){
  .resizer { width:5px; cursor:col-resize; }
  .resizer-handle { width:3px; height:32px; }
}
/* mobile: horizontal resizer */
@media(max-width:768px){
  .resizer { height:10px; width:100%; cursor:row-resize; flex-direction:row; }
  .resizer-handle { height:3px; width:32px; }
}

/* ── Responsive ──────────────────────────────── */
@media(max-width:768px){
  .app{flex-direction:column;}
  .sidebar{width:100%;min-width:100%;height:55vh;border-right:none;}
  .map-wrap{flex-shrink:0;}
  input, select, textarea { font-size: 16px !important; }
}
