/* ============================================================
   Japan Trip Planner – Stylesheet  v3
   ============================================================ */

/* ── Light theme ────────────────────────────────────────────── */
:root {
  --c-bg:          #FAF8F5;
  --c-bg-card:     #FFFFFF;
  --c-bg-muted:    #F3EFE9;
  --c-primary:     #C9184A;
  --c-primary-dk:  #A01040;
  --c-sakura:      #FFAFC5;
  --c-sakura-lt:   #FFF0F4;
  --c-text:        #2B2B2B;
  --c-text-muted:  #7A7A8C;
  --c-text-light:  #AFA9B8;
  --c-border:      #E8E1D9;
  --c-border-lt:   #F0EBE4;
  --c-success:     #2A9D5C;
  --c-success-bg:  #EDFAF3;
  --c-planned:     #E6900A;
  --c-planned-bg:  #FFF8EC;
  --c-maps:        #2E7D32;
  --c-maps-bg:     #E8F5E9;
  --c-maps-border: #C8E6C9;

  --shadow-xs: 0 1px 3px rgba(0,0,0,.07);
  --shadow-sm: 0 2px 10px rgba(0,0,0,.08);
  --shadow-md: 0 4px 20px rgba(0,0,0,.10);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.14);

  --r-sm: 6px; --r-md: 12px; --r-lg: 18px; --r-xl: 24px;
  --font-sans:  'Noto Sans JP', 'Helvetica Neue', Arial, sans-serif;
  --font-serif: 'Noto Serif JP', Georgia, serif;
  --header-h: 64px; --controls-h: 60px;
  --max-w: 1400px; --pad-page: 24px;
}

/* ── Dark theme ─────────────────────────────────────────────── */
html[data-theme="dark"] {
  --c-bg:          #0E0E18;
  --c-bg-card:     #17172A;
  --c-bg-muted:    #1E1E33;
  --c-primary:     #FF4D6D;
  --c-primary-dk:  #C9184A;
  --c-sakura:      #FF8FA3;
  --c-sakura-lt:   #2B141E;
  --c-text:        #E8E8F0;
  --c-text-muted:  #9090AA;
  --c-text-light:  #55556A;
  --c-border:      #2C2C46;
  --c-border-lt:   #222238;
  --c-success:     #3DD68C;
  --c-success-bg:  #0D2A1E;
  --c-planned:     #FFAA33;
  --c-planned-bg:  #2A1F08;
  --c-maps:        #66BB6A;
  --c-maps-bg:     #0F2214;
  --c-maps-border: #1B3B1F;
  --shadow-xs: 0 1px 3px rgba(0,0,0,.30);
  --shadow-sm: 0 2px 10px rgba(0,0,0,.35);
  --shadow-md: 0 4px 20px rgba(0,0,0,.40);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.55);
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
.hidden { display: none !important; }
body { font-family: var(--font-sans); font-size: 14px; line-height: 1.6; color: var(--c-text); background: var(--c-bg); min-height: 100vh; transition: background .25s, color .25s; }
a { color: var(--c-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
button { cursor: pointer; font-family: inherit; }

/* ── Buttons ────────────────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 9px 18px; border: none; border-radius: var(--r-md); font-size: 13.5px; font-weight: 500; transition: all .18s; white-space: nowrap; }
.btn-primary { background: var(--c-primary); color: #fff; box-shadow: 0 2px 8px rgba(201,24,74,.30); }
.btn-primary:hover  { background: var(--c-primary-dk); transform: translateY(-1px); }
.btn-primary:active { transform: none; }
.btn-ghost { background: transparent; color: var(--c-text-muted); border: 1.5px solid var(--c-border); }
.btn-ghost:hover { background: var(--c-bg-muted); color: var(--c-text); }
.btn-full { width: 100%; justify-content: center; padding: 13px; font-size: 15px; }

/* ── Form Elements ──────────────────────────────────────────── */
.text-input, .select-input { width: 100%; padding: 10px 14px; border: 1.5px solid var(--c-border); border-radius: var(--r-md); font-family: var(--font-sans); font-size: 14px; color: var(--c-text); background: var(--c-bg-card); transition: border-color .15s, box-shadow .15s; outline: none; appearance: none; -webkit-appearance: none; }
.text-input::placeholder { color: var(--c-text-light); }
.text-input:focus, .select-input:focus { border-color: var(--c-primary); box-shadow: 0 0 0 3px rgba(201,24,74,.10); }
.textarea-input { resize: vertical; min-height: 90px; }
.text-readonly { background: var(--c-bg-muted) !important; color: var(--c-text-muted); cursor: default; }
.select-input { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A7A8C' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 36px; }
.select-sm { width: auto; padding: 7px 32px 7px 11px; font-size: 13px; }

/* ── HEADER ─────────────────────────────────────────────────── */
.app-header { position: sticky; top: 0; z-index: 100; background: var(--c-bg-card); border-bottom: 1px solid var(--c-border); box-shadow: var(--shadow-sm); height: var(--header-h); transition: background .25s; }
.app-header::before { content: ''; position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Ccircle cx='30' cy='30' r='2' fill='%23FFAFC5' opacity='0.15'/%3E%3Ccircle cx='10' cy='10' r='1' fill='%23FFAFC5' opacity='0.10'/%3E%3C/svg%3E"); pointer-events: none; }
.header-inner { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--pad-page); height: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.header-brand { display: flex; align-items: center; gap: 14px; }
.header-mon { width: 44px; height: 44px; background: var(--c-primary); color: #fff; font-family: var(--font-serif); font-size: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 2px 10px rgba(201,24,74,.35); flex-shrink: 0; }
.header-text h1 { font-family: var(--font-serif); font-size: 20px; font-weight: 700; line-height: 1.1; }
.header-sub { font-size: 11.5px; color: var(--c-text-muted); }
.header-right { display: flex; align-items: center; gap: 10px; }
.theme-toggle { width: 36px; height: 36px; background: var(--c-bg-muted); border: 1.5px solid var(--c-border); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 17px; transition: background .15s, transform .2s; }
.theme-toggle:hover { background: var(--c-sakura-lt); transform: rotate(20deg); }
.user-chip-wrap { position: relative; }
.user-chip { display: flex; align-items: center; background: var(--c-sakura-lt); border: 1.5px solid var(--c-sakura); border-radius: 999px; padding: 4px; cursor: pointer; transition: background .15s, border-color .15s; }
.user-chip:hover { background: var(--c-sakura); border-color: var(--c-primary); }
.user-avatar { width: 32px; height: 32px; background: var(--c-primary); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; line-height: 1; flex-shrink: 0; pointer-events: none; }

/* ── Profile popup ───────────────────────────────────────────── */
.profile-popup {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  min-width: 190px;
  background: var(--c-bg-card);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  padding: 20px 18px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 150;
  animation: slideUp .15s ease;
}
/* Arrow pointing up toward avatar */
.profile-popup::before {
  content: '';
  position: absolute;
  top: -7px;
  right: 14px;
  width: 12px;
  height: 12px;
  background: var(--c-bg-card);
  border-left: 1.5px solid var(--c-border);
  border-top: 1.5px solid var(--c-border);
  transform: rotate(45deg);
}
.profile-popup.hidden { display: none; }
.profile-popup-emoji  { font-size: 48px; line-height: 1; margin-bottom: 2px; }
.profile-popup-name   { font-size: 15px; font-weight: 700; color: var(--c-text); }
.profile-popup-divider { width: 100%; border: none; border-top: 1px solid var(--c-border-lt); margin: 4px 0; }
.profile-popup-logout {
  width: 100%;
  padding: 8px 14px;
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-sm);
  background: none;
  color: var(--c-text-muted);
  font-size: 13px;
  font-family: inherit;
  cursor: pointer;
  transition: all .15s;
}
.profile-popup-logout:hover { background: var(--c-sakura-lt); color: var(--c-primary); border-color: var(--c-sakura); }

/* ── CONTROLS BAR ───────────────────────────────────────────── */
.controls-bar { background: var(--c-bg-card); border-bottom: 1px solid var(--c-border-lt); position: sticky; top: var(--header-h); z-index: 90; box-shadow: 0 2px 6px rgba(0,0,0,.04); transition: background .25s; }
.controls-inner { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--pad-page); height: var(--controls-h); display: flex; align-items: center; gap: 10px; overflow-x: auto; scrollbar-width: none; }
.controls-inner::-webkit-scrollbar { display: none; }
.view-switcher { display: flex; background: var(--c-bg-muted); border-radius: var(--r-sm); padding: 3px; gap: 2px; flex-shrink: 0; }
.view-btn { background: none; border: none; padding: 6px 8px; border-radius: calc(var(--r-sm) - 1px); color: var(--c-text-muted); transition: all .15s; display: flex; align-items: center; }
.view-btn:hover  { background: var(--c-bg-card); color: var(--c-text); }
.view-btn.active { background: var(--c-bg-card); color: var(--c-primary); box-shadow: var(--shadow-xs); }
.search-wrap { position: relative; flex: 1; min-width: 140px; max-width: 280px; }
.search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--c-text-light); pointer-events: none; }
.search-input { width: 100%; padding: 7px 12px 7px 34px; border: 1.5px solid var(--c-border); border-radius: var(--r-md); font-size: 13px; outline: none; background: var(--c-bg); color: var(--c-text); transition: border-color .15s; }
.search-input:focus { border-color: var(--c-primary); background: var(--c-bg-card); }
.stats-wrap { display: flex; gap: 6px; flex-shrink: 0; margin-left: auto; }
.stat-chip { background: var(--c-bg-muted); border: 1px solid var(--c-border); border-radius: 999px; padding: 4px 11px; font-size: 12px; color: var(--c-text-muted); white-space: nowrap; }
.stat-visited { background: var(--c-success-bg); border-color: #b7e8cc; color: var(--c-success); }

/* ── MAIN CONTENT ───────────────────────────────────────────── */
.main-content { max-width: var(--max-w); margin: 0 auto; padding: 28px var(--pad-page) 80px; }
.initial-loader { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 80px 0; color: var(--c-text-muted); }
.spinner { width: 36px; height: 36px; border: 3px solid var(--c-border); border-top-color: var(--c-primary); border-radius: 50%; animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.empty-state { text-align: center; padding: 80px 20px; color: var(--c-text-muted); }
.empty-state-icon { font-size: 56px; display: block; margin-bottom: 16px; opacity: .6; }
.empty-state h3 { font-size: 18px; font-weight: 600; color: var(--c-text); margin-bottom: 8px; }

/* ── CARD VIEW ──────────────────────────────────────────────── */
.cards-grid { columns: 4 280px; column-gap: 18px; }
.place-card { break-inside: avoid; display: block; background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--r-lg); margin-bottom: 18px; overflow: hidden; box-shadow: var(--shadow-sm); transition: transform .2s, box-shadow .2s; cursor: pointer; }
.place-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }

/* Card cover photo */
.card-photo { width: 100%; height: 160px; background-size: cover; background-position: center; background-color: var(--c-bg-muted); position: relative; }
.card-photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom, transparent 40%, rgba(0,0,0,.35) 100%); }

/* Color bar (shown when no photo) */
.card-color-bar { height: 4px; }
[data-cat="Temple"]        .card-color-bar { background: #8B4513; }
[data-cat="Shrine"]        .card-color-bar { background: var(--c-primary); }
[data-cat="Restaurant"]    .card-color-bar { background: #E65100; }
[data-cat="Nature"]        .card-color-bar { background: #2E7D32; }
[data-cat="Shopping"]      .card-color-bar { background: #6A1B9A; }
[data-cat="Accommodation"] .card-color-bar { background: #1565C0; }
[data-cat="Bar"]           .card-color-bar { background: #B8860B; }
[data-cat="Attraction"]    .card-color-bar { background: #00838F; }
[data-cat="Curiosity"]     .card-color-bar { background: #6D4C41; }
[data-cat="Museum"]        .card-color-bar { background: #37474F; }
[data-cat="Other"]         .card-color-bar { background: #546E7A; }

.card-body { padding: 14px 16px 12px; }
.card-header { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 8px; }
.card-category-icon { font-size: 20px; line-height: 1; flex-shrink: 0; margin-top: 2px; }
.card-name { font-size: 15px; font-weight: 600; line-height: 1.3; word-break: break-word; }
.card-category-label { font-size: 11px; color: var(--c-text-muted); margin-top: 2px; }
.card-desc { font-size: 13px; color: var(--c-text-muted); line-height: 1.55; margin-bottom: 10px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.card-footer { display: flex; flex-direction: column; gap: 8px; }
.card-meta { display: flex; align-items: center; justify-content: space-between; gap: 6px; }
.card-suggester { font-size: 11.5px; color: var(--c-text-light); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.card-suggester strong { color: var(--c-text-muted); }
.card-pills { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
.card-cat-pill { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 999px; font-size: 11.5px; font-weight: 500; background: var(--c-bg-muted); border: 1px solid var(--c-border); color: var(--c-text-muted); white-space: nowrap; }

/* Status badges */
.status-badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 999px; font-size: 11.5px; font-weight: 500; cursor: pointer; border: none; transition: filter .15s; }
.status-badge:hover { filter: brightness(.92); }
.status-badge.bookmark { background: #EEF2FF; color: #4338CA; border: 1px solid #C7D2FE; }
.status-badge.planned  { background: var(--c-planned-bg); color: var(--c-planned); border: 1px solid #f0d08a; }
.status-badge.visited  { background: var(--c-success-bg); color: var(--c-success); border: 1px solid #b7e8cc; }
html[data-theme="dark"] .status-badge.bookmark { background: #1e1b4b; color: #818CF8; border-color: #3730a3; }

/* Reactions */
.card-reactions { display: flex; align-items: center; gap: 4px; flex-wrap: wrap; }
.reaction-chip { display: inline-flex; align-items: center; gap: 3px; padding: 3px 8px; border-radius: 999px; background: var(--c-bg-muted); border: 1.5px solid var(--c-border); font-size: 13px; cursor: pointer; transition: all .15s; line-height: 1; }
.reaction-chip:hover  { background: var(--c-sakura-lt); border-color: var(--c-sakura); }
.reaction-chip.active { background: var(--c-sakura-lt); border-color: var(--c-primary); box-shadow: 0 0 0 2px rgba(201,24,74,.12); }
.reaction-count { font-size: 11.5px; color: var(--c-text-muted); font-weight: 600; }
.card-add-reaction { display: inline-flex; align-items: center; gap: 3px; padding: 3px 8px; border-radius: 999px; background: none; border: 1.5px dashed var(--c-border); font-size: 13px; color: var(--c-text-light); cursor: pointer; transition: all .15s; }
.card-add-reaction:hover { border-color: var(--c-sakura); color: var(--c-primary); background: var(--c-sakura-lt); }

/* Card actions */
.card-actions { display: flex; align-items: center; gap: 4px; justify-content: flex-end; flex-wrap: wrap; }
.card-maps-btn { display: inline-flex; align-items: center; gap: 4px; padding: 5px 10px; border-radius: var(--r-sm); background: var(--c-maps-bg); border: 1px solid var(--c-maps-border); color: var(--c-maps); font-size: 12px; font-weight: 500; text-decoration: none; transition: filter .15s; }
.card-maps-btn:hover { filter: brightness(.92); text-decoration: none; }
.card-website-btn { display: inline-flex; align-items: center; gap: 4px; padding: 5px 10px; border-radius: var(--r-sm); background: var(--c-bg-muted); border: 1px solid var(--c-border); color: var(--c-text-muted); font-size: 12px; font-weight: 500; text-decoration: none; transition: filter .15s; }
.card-website-btn:hover { filter: brightness(.92); text-decoration: none; }
.card-edit-btn, .card-delete-btn { background: none; border: none; padding: 5px 7px; border-radius: var(--r-sm); font-size: 13px; color: var(--c-text-muted); transition: background .15s; }
.card-edit-btn:hover   { background: var(--c-planned-bg); color: var(--c-planned); }
.card-delete-btn:hover { background: #FFF0F0; color: #C62828; }

/* ── LIST VIEW ──────────────────────────────────────────────── */
.list-table-wrap { background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.list-table { width: 100%; border-collapse: collapse; }
.list-table thead tr { background: var(--c-bg-muted); border-bottom: 1px solid var(--c-border); }
.list-table th { padding: 10px 14px; text-align: left; font-size: 11.5px; font-weight: 600; color: var(--c-text-muted); text-transform: uppercase; letter-spacing: .05em; white-space: nowrap; }
.list-table tbody tr { border-bottom: 1px solid var(--c-border-lt); transition: background .12s; cursor: pointer; }
.list-table tbody tr:last-child { border-bottom: none; }
.list-table tbody tr:hover { background: var(--c-bg-muted); }
.list-table td { padding: 11px 14px; vertical-align: middle; font-size: 13.5px; }
.list-name { font-weight: 600; display: flex; align-items: center; gap: 10px; }
.list-name small { display: block; font-weight: 400; font-size: 12px; color: var(--c-text-muted); max-width: 240px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.list-thumb { width: 40px; height: 40px; object-fit: cover; border-radius: var(--r-sm); flex-shrink: 0; }
.list-cat-icon { font-size: 20px; flex-shrink: 0; }
.list-reactions { display: flex; gap: 4px; flex-wrap: wrap; }
.list-actions { display: flex; gap: 2px; }

/* ── MAP VIEW ───────────────────────────────────────────────── */
.map-container { display: flex; gap: 20px; height: calc(100vh - var(--header-h) - var(--controls-h) - 56px); min-height: 500px; }
#leafletMap { flex: 1; min-width: 0; border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-md); border: 1px solid var(--c-border); z-index: 1; }
.map-sidebar { width: 300px; flex-shrink: 0; background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--r-lg); overflow-y: auto; }
.map-sidebar-header { padding: 14px 16px; border-bottom: 1px solid var(--c-border-lt); font-weight: 600; font-size: 13px; color: var(--c-text-muted); background: var(--c-bg-muted); border-radius: var(--r-lg) var(--r-lg) 0 0; }
.map-place-item { padding: 12px 16px; border-bottom: 1px solid var(--c-border-lt); cursor: pointer; transition: background .12s; display: flex; gap: 10px; align-items: flex-start; }
.map-place-item:last-child { border-bottom: none; }
.map-place-item:hover { background: var(--c-sakura-lt); }
.map-place-item.no-coords { opacity: .5; cursor: default; }
.map-place-item.no-coords:hover { background: transparent; }
.map-place-icon { font-size: 18px; flex-shrink: 0; margin-top: 1px; }
.map-sidebar-thumb { width: 38px; height: 38px; object-fit: cover; border-radius: var(--r-sm); flex-shrink: 0; }
.map-place-name { font-weight: 600; font-size: 13px; }
.map-place-cat  { font-size: 11.5px; color: var(--c-text-muted); }
.map-no-coords  { font-size: 10.5px; color: var(--c-text-light); font-style: italic; }
.leaflet-popup-content-wrapper { border-radius: var(--r-md) !important; box-shadow: var(--shadow-md) !important; font-family: var(--font-sans) !important; }

/* ── MODALS ─────────────────────────────────────────────────── */
.modal-overlay { position: fixed; inset: 0; background: rgba(15,10,25,.60); backdrop-filter: blur(4px); z-index: 200; display: flex; align-items: center; justify-content: center; padding: 20px; animation: fadeIn .2s ease; }
.modal-overlay.hidden { display: none; }
@keyframes fadeIn  { from { opacity: 0; } }
@keyframes slideUp { from { transform: translateY(20px); opacity: 0; } }
.modal-box { background: var(--c-bg-card); border-radius: var(--r-xl); box-shadow: var(--shadow-lg); width: 100%; max-width: 460px; animation: slideUp .22s ease; max-height: 90vh; overflow-y: auto; transition: background .25s; }
.modal-large  { max-width: 660px; }
.modal-center { text-align: center; padding: 40px 36px; }
.modal-kanji  { font-family: var(--font-serif); font-size: 64px; color: var(--c-primary); opacity: .15; line-height: 1; margin-bottom: 12px; }
.modal-center h2 { font-family: var(--font-serif); font-size: 22px; margin-bottom: 8px; }
.modal-subtitle  { font-size: 14px; color: var(--c-text-muted); margin-bottom: 24px; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 22px 26px 0; margin-bottom: 20px; }
.modal-header h2 { font-family: var(--font-serif); font-size: 19px; }
.modal-close { width: 32px; height: 32px; background: var(--c-bg-muted); border: none; border-radius: 50%; font-size: 20px; color: var(--c-text-muted); display: flex; align-items: center; justify-content: center; transition: all .15s; }
.modal-close:hover { background: #FFE5E5; color: #C62828; }
.modal-box form { padding: 0 26px 26px; display: flex; flex-direction: column; gap: 14px; }
.form-row { display: grid; grid-template-columns: 1fr auto; gap: 12px; }
.form-group-grow { min-width: 0; }
.form-group { display: flex; flex-direction: column; gap: 5px; }
.form-group label { font-size: 12.5px; font-weight: 600; color: var(--c-text-muted); text-transform: uppercase; letter-spacing: .04em; }
.required { color: var(--c-primary); }
.label-optional { font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--c-text-light); }
.label-readonly { font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--c-text-light); font-size: 11px; background: var(--c-bg-muted); padding: 1px 6px; border-radius: 4px; margin-left: 4px; }
.label-hint { display: block; font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--c-text-light); font-size: 11.5px; margin-top: 2px; }
.coords-label-row { display: flex; align-items: center; justify-content: space-between; }
.edit-coords-btn { background: none; border: none; font-size: 11.5px; color: var(--c-primary); cursor: pointer; padding: 0; font-family: inherit; font-weight: 500; transition: opacity .15s; }
.edit-coords-btn:hover { opacity: .75; text-decoration: underline; }
.text-input:disabled { background: var(--c-bg-muted) !important; color: var(--c-text-light); cursor: not-allowed; }
.coords-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.form-actions { display: flex; justify-content: flex-end; gap: 10px; padding-top: 6px; border-top: 1px solid var(--c-border-lt); margin-top: 4px; }

/* ── PROFILE MODAL ──────────────────────────────────────────── */
.profile-select-box { max-width: 520px; }
.profile-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 8px; }
.profile-card { display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 24px 16px; border-radius: var(--r-lg); background: var(--c-bg-muted); border: 2px solid var(--c-border); cursor: pointer; transition: all .18s; }
.profile-card:hover { border-color: var(--c-primary); background: var(--c-sakura-lt); transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.profile-card-emoji { font-size: 44px; line-height: 1; }
.profile-card-name  { font-size: 15px; font-weight: 600; }
.profile-loading    { grid-column: 1/-1; display: flex; justify-content: center; padding: 30px 0; }
.pw-back-btn  { background: none; border: none; color: var(--c-text-muted); font-size: 13px; cursor: pointer; margin-bottom: 16px; }
.pw-back-btn:hover { color: var(--c-primary); }
.pw-avatar    { font-size: 52px; line-height: 1; margin-bottom: 12px; }
.pw-error     { color: #C62828; font-size: 13px; margin-top: 6px; }
.pw-error.hidden { display: none; }
.modal-center .text-input { margin-bottom: 8px; font-size: 15px; padding: 12px 16px; }

/* ── IMPORT SECTION ─────────────────────────────────────────── */
.import-section { border: 1.5px solid var(--c-border); border-radius: var(--r-md); overflow: hidden; }

/* Header bar (replaces the old toggle button) */
.import-section-header {
  display: flex; align-items: center; gap: 8px;
  padding: 11px 16px;
  background: var(--c-bg-muted);
  border-bottom: 1px solid var(--c-border);
  font-size: 13.5px; font-weight: 600; color: var(--c-text-muted);
}
.import-section-icon { font-size: 15px; }

.import-panel { padding: 14px 16px; display: flex; flex-direction: column; gap: 12px; }

/* "Add data manually" separator row */
.add-manually-wrap {
  display: flex; align-items: center; gap: 12px;
  color: var(--c-text-light); font-size: 12.5px;
}
.add-manually-wrap::before,
.add-manually-wrap::after {
  content: ''; flex: 1; height: 1px; background: var(--c-border-lt);
}
.add-manually-btn {
  flex-shrink: 0;
  background: none;
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-sm);
  padding: 6px 14px;
  font-size: 12.5px; font-family: inherit;
  color: var(--c-text-muted); cursor: pointer;
  transition: all .15s; white-space: nowrap;
}
.add-manually-btn:hover { background: var(--c-bg-muted); color: var(--c-text); border-color: var(--c-text-light); }
.import-url-row { display: flex; gap: 8px; }
.import-url-row .text-input { flex: 1; }
.import-url-row .btn { flex-shrink: 0; }

/* Status feedback */
.import-status { display: flex; align-items: center; gap: 8px; font-size: 13px; border-radius: var(--r-sm); padding: 8px 12px; }
.import-status.hidden  { display: none; }
.import-status.loading { background: var(--c-bg-muted); color: var(--c-text-muted); }
.import-status.error   { background: #FFF0F0; color: #C62828; border: 1px solid #FFCDD2; }
.import-status.success { background: var(--c-success-bg); color: var(--c-success); border: 1px solid #b7e8cc; }
.import-status-spinner { width: 16px; height: 16px; border: 2px solid var(--c-border); border-top-color: var(--c-primary); border-radius: 50%; animation: spin .6s linear infinite; flex-shrink: 0; }

/* Results */
.import-results { display: flex; flex-direction: column; gap: 12px; }
.import-results.hidden { display: none; }

.import-address-row { display: flex; align-items: center; gap: 8px; padding: 8px 12px; background: var(--c-success-bg); border: 1px solid #b7e8cc; border-radius: var(--r-sm); }
.import-address-pin  { font-size: 16px; flex-shrink: 0; }
.import-address-text { flex: 1; font-size: 13px; color: var(--c-success); font-weight: 500; }
.import-clear-btn    { background: none; border: none; font-size: 14px; color: var(--c-text-light); cursor: pointer; padding: 2px 4px; border-radius: 4px; flex-shrink: 0; }
.import-clear-btn:hover { background: rgba(0,0,0,.08); color: var(--c-text); }

/* Photo selection grid */
.import-photo-section { display: flex; flex-direction: column; gap: 8px; }
.import-photo-section.hidden { display: none; }
.import-photo-label { font-size: 12px; font-weight: 600; color: var(--c-text-muted); text-transform: uppercase; letter-spacing: .04em; }
.import-photo-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.photo-thumb {
  aspect-ratio: 4/3;
  border-radius: var(--r-sm);
  overflow: hidden;
  cursor: pointer;
  border: 2.5px solid transparent;
  transition: all .15s;
  position: relative;
  background: var(--c-bg-muted);
}
.photo-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.photo-thumb:hover   { border-color: var(--c-primary); transform: scale(1.04); }
.photo-thumb.selected { border-color: var(--c-primary); box-shadow: 0 0 0 3px rgba(201,24,74,.20); }
.photo-thumb.selected::after { content: '✓'; position: absolute; inset: 0; background: rgba(201,24,74,.35); display: flex; align-items: center; justify-content: center; font-size: 24px; color: #fff; font-weight: 700; }
.photo-thumb-loading { aspect-ratio: 4/3; border-radius: var(--r-sm); background: var(--c-bg-muted); display: flex; align-items: center; justify-content: center; }
.photo-downloading { opacity: .5; pointer-events: none; }

/* ── DETAIL MODAL ───────────────────────────────────────────── */
.modal-detail { max-width: 620px; padding: 0; }
.detail-photo { width: 100%; height: 220px; background-size: cover; background-position: center; background-color: var(--c-bg-muted); border-radius: var(--r-xl) var(--r-xl) 0 0; }
.detail-photo.hidden { display: none; }
.detail-top-bar { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px 0; }
.detail-cat-badge { display: inline-flex; align-items: center; gap: 6px; padding: 5px 14px; border-radius: 999px; font-size: 13px; font-weight: 600; background: var(--c-bg-muted); border: 1px solid var(--c-border); }
.detail-body { padding: 16px 24px 28px; display: flex; flex-direction: column; gap: 16px; }
.detail-title   { font-family: var(--font-serif); font-size: 22px; font-weight: 700; line-height: 1.25; }
.detail-address { font-size: 13px; color: var(--c-text-muted); margin-top: -10px; }
.detail-description { font-size: 14px; color: var(--c-text-muted); line-height: 1.65; white-space: pre-wrap; word-break: break-word; }
.detail-meta-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.detail-suggester { font-size: 13px; color: var(--c-text-light); }
.detail-suggester strong { color: var(--c-text-muted); }
.detail-date    { font-size: 12px; color: var(--c-text-light); margin-left: auto; }
.detail-maps-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; border-radius: var(--r-md); background: var(--c-maps-bg); border: 1.5px solid var(--c-maps-border); color: var(--c-maps); font-size: 14px; font-weight: 600; text-decoration: none; transition: filter .15s, transform .15s; }
.detail-maps-btn:hover { filter: brightness(.92); transform: translateY(-1px); text-decoration: none; }
.detail-website-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; border-radius: var(--r-md); background: var(--c-bg-muted); border: 1.5px solid var(--c-border); color: var(--c-text-muted); font-size: 14px; font-weight: 600; text-decoration: none; transition: filter .15s, transform .15s; }
.detail-website-btn:hover { filter: brightness(.92); transform: translateY(-1px); text-decoration: none; }
.detail-action-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.btn-sm { padding: 6px 12px; font-size: 12.5px; }
.detail-reactions-section { display: flex; flex-direction: column; gap: 10px; }
.detail-reactions-label { font-size: 12px; font-weight: 600; color: var(--c-text-muted); text-transform: uppercase; letter-spacing: .05em; }
.detail-reactions { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.add-reaction-btn { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: 999px; background: none; border: 1.5px dashed var(--c-border); color: var(--c-text-muted); font-size: 13px; cursor: pointer; transition: all .15s; }
.add-reaction-btn:hover { border-color: var(--c-primary); color: var(--c-primary); background: var(--c-sakura-lt); }
.nearby-section { display: flex; flex-direction: column; gap: 12px; border-top: 1px solid var(--c-border-lt); padding-top: 18px; }
.nearby-title { font-size: 13px; font-weight: 700; }
.nearby-grid  { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
.nearby-card  { display: flex; flex-direction: column; gap: 4px; padding: 10px 12px; border-radius: var(--r-md); background: var(--c-bg-muted); border: 1px solid var(--c-border); cursor: pointer; transition: all .15s; }
.nearby-card:hover { background: var(--c-sakura-lt); border-color: var(--c-sakura); }
.nearby-card-icon { font-size: 18px; }
.nearby-card-photo { width: 100%; height: 52px; object-fit: cover; border-radius: calc(var(--r-sm) - 1px); margin-bottom: 2px; }
.nearby-card-name { font-weight: 600; font-size: 12px; line-height: 1.3; word-break: break-word; }
.nearby-card-dist { font-size: 11px; color: var(--c-text-light); }
.nearby-empty { font-size: 13px; color: var(--c-text-light); font-style: italic; }

/* ── EMOJI PICKER ───────────────────────────────────────────── */
.emoji-picker-backdrop { position: fixed; inset: 0; z-index: 299; }
.emoji-picker-backdrop.hidden { display: none; }
.emoji-picker { position: fixed; z-index: 300; width: 340px; max-height: 420px; background: var(--c-bg-card); border: 1.5px solid var(--c-border); border-radius: var(--r-lg); box-shadow: var(--shadow-lg); display: flex; flex-direction: column; overflow: hidden; animation: slideUp .18s ease; }
.emoji-picker.hidden { display: none; }
.emoji-picker-header { padding: 10px 10px 6px; border-bottom: 1px solid var(--c-border-lt); display: flex; flex-direction: column; gap: 6px; flex-shrink: 0; }
.emoji-search { width: 100%; padding: 7px 12px; border: 1.5px solid var(--c-border); border-radius: var(--r-sm); font-size: 13px; outline: none; background: var(--c-bg); color: var(--c-text); }
.emoji-search:focus { border-color: var(--c-primary); }
.emoji-cat-tabs { display: flex; gap: 2px; overflow-x: auto; scrollbar-width: none; }
.emoji-cat-tabs::-webkit-scrollbar { display: none; }
.emoji-cat-tab { flex-shrink: 0; background: none; border: none; padding: 4px 7px; border-radius: var(--r-sm); font-size: 16px; cursor: pointer; opacity: .6; transition: all .12s; }
.emoji-cat-tab:hover  { background: var(--c-bg-muted); opacity: 1; }
.emoji-cat-tab.active { background: var(--c-bg-muted); opacity: 1; }
.emoji-grid { display: grid; grid-template-columns: repeat(8, 1fr); gap: 2px; padding: 8px; overflow-y: auto; flex: 1; }
.emoji-btn { aspect-ratio: 1; border: none; background: none; font-size: 20px; border-radius: var(--r-sm); cursor: pointer; transition: background .1s; display: flex; align-items: center; justify-content: center; line-height: 1; }
.emoji-btn:hover { background: var(--c-bg-muted); }
.emoji-cat-label { grid-column: 1/-1; font-size: 10.5px; font-weight: 700; color: var(--c-text-light); text-transform: uppercase; letter-spacing: .06em; padding: 4px 2px 2px; }

/* ── TOAST ──────────────────────────────────────────────────── */
#toastContainer { position: fixed; bottom: 24px; right: 24px; z-index: 400; display: flex; flex-direction: column; gap: 8px; pointer-events: none; }
.toast { display: flex; align-items: center; gap: 10px; background: #1A1A2E; color: #fff; padding: 12px 18px; border-radius: var(--r-md); font-size: 13.5px; box-shadow: var(--shadow-lg); animation: toastIn .25s ease; pointer-events: auto; max-width: 320px; }
.toast.success { background: #1a3a2a; border-left: 3px solid var(--c-success); }
.toast.error   { background: #3a1a1a; border-left: 3px solid #C62828; }
@keyframes toastIn  { from { opacity: 0; transform: translateX(20px); } }
@keyframes toastOut { to   { opacity: 0; transform: translateX(20px); } }

/* ── POLL INDICATOR ─────────────────────────────────────────── */
.poll-indicator { position: fixed; bottom: 24px; left: 24px; display: flex; align-items: center; gap: 6px; background: rgba(255,255,255,.9); border: 1px solid var(--c-border); border-radius: 999px; padding: 5px 12px; font-size: 11.5px; color: var(--c-text-muted); box-shadow: var(--shadow-xs); backdrop-filter: blur(4px); }
html[data-theme="dark"] .poll-indicator { background: rgba(23,23,42,.9); }
.poll-dot { width: 7px; height: 7px; background: var(--c-success); border-radius: 50%; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.8)} }
.poll-indicator.error .poll-dot { background: #C62828; animation: none; }

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 900px) {
  :root { --pad-page: 16px; }
  .cards-grid { columns: 2 260px; }
  .map-container { flex-direction: column; height: auto; }
  .map-sidebar { width: 100%; max-height: 260px; }
  #leafletMap { height: 340px; }
  .header-sub { display: none; }
  .nearby-grid { grid-template-columns: 1fr 1fr; }
  .import-photo-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 600px) {
  :root { --pad-page: 12px; }
  .cards-grid { columns: 1; }
  .header-text h1 { font-size: 17px; }
  .user-chip-name { display: none; }
  .stats-wrap { display: none; }
  .list-table-wrap { overflow-x: auto; }
  .list-table { min-width: 600px; }
  #toastContainer { right: 12px; bottom: 12px; }
  .poll-indicator { display: none; }
  .modal-center { padding: 28px 18px; }
  .modal-box form { padding: 0 18px 22px; }
  .form-row { grid-template-columns: 1fr; }
  .import-photo-grid { grid-template-columns: repeat(3, 1fr); }
  .nearby-grid { grid-template-columns: 1fr 1fr; }
  .emoji-picker { width: calc(100vw - 32px); }
}
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--c-border); border-radius: 3px; }
