:root{
  --bg:#f6fbf8;
  --fg:#17211c;
  --muted:#64746d;
  --app-header-height:42px;
  --map-panel-height:340px;
  --rain-radar-controls-height:33px;
  --time-simulation-controls-height:33px;
  --list-sticky-top:0px;
  --brand-500:#2f7d5b;
  --brand-600:#2b6f50;
  --brand-700:#1f563e;
  --line:#d6eadf;
  --surface:#ffffff;
  --surface-soft:#fbfefc;
  --status-open-bg:#d9f8e7;
  --status-open-fg:#166534;
  --status-soon-bg:#fff5d8;
  --status-soon-fg:#8a5600;
  --status-urgent-bg:#ffe5e5;
  --status-urgent-fg:#a91f16;
  --status-closed-bg:#eef2f0;
  --status-closed-fg:#667085;
}
[data-theme=light]{
  color-scheme: light;
  --color-base-100: oklch(100% 0 0);
  --color-base-200: oklch(98% 0.012 150);
  --color-base-300: oklch(93% 0.03 150);
  --color-base-content: oklch(25% 0.04 150);
  --color-primary: oklch(48% 0.11 155);
  --color-primary-content: oklch(98% 0.01 155);
  --color-secondary: oklch(72% 0.13 78);
  --color-secondary-content: oklch(24% 0.04 78);
  --color-accent: oklch(65% 0.13 345);
  --color-accent-content: oklch(98% 0.01 345);
  --color-neutral: oklch(40% 0.04 150);
  --color-neutral-content: oklch(98% 0.01 150);
  --color-info: oklch(70% 0.11 230);
  --color-info-content: oklch(20% 0.04 230);
  --color-success: oklch(62% 0.13 150);
  --color-success-content: oklch(98% 0.01 150);
  --color-warning: oklch(78% 0.16 80);
  --color-warning-content: oklch(24% 0.04 80);
  --color-error: oklch(63% 0.16 28);
  --color-error-content: oklch(98% 0.01 28);
  --radius-selector: 0.5rem;
  --radius-field: 0.375rem;
  --radius-box: 0.75rem;
  --size-selector: 0.25rem;
  --size-field: 0.25rem;
  --border: 1px;
  --depth: 0;
  --noise: 0;
}

*{box-sizing:border-box}
html{min-height:100%;overflow-x:clip}
body{min-height:100%;margin:0;overflow-x:clip;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans JP",sans-serif;font-size:13px;line-height:1.35;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased}
.app-sticky-shell{position:sticky;top:0;z-index:30}
.app-header{min-height:var(--app-header-height);padding:4px 12px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.95);box-shadow:0 1px 0 rgba(31,86,62,0.08)}
.app-header-inner{display:flex;align-items:center;justify-content:space-between;gap:8px}
.app-menu-button{flex:0 0 auto;color:var(--brand-700);font-size:17px}
.app-header-inner .app-title{margin-right:auto}
.app-title{display:flex;align-items:center;gap:8px;margin:0;color:var(--brand-700);font-size:15px;font-weight:700;line-height:1.2}
.app-active-view-badge{display:inline-flex;align-items:center;min-width:0;max-width:min(48vw,280px);height:22px;padding:0 8px;border:1px solid #b8dcc8;border-radius:999px;background:#edf8f2;color:#276248;font-size:11px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.app-title-icon{display:grid;place-items:center;width:32px;height:32px;border-radius:8px;background:#e3f3ea;color:var(--brand-600)}
.app-title-icon i{font-size:14px}
.app-drawer-side{z-index:80}
.app-drawer-panel{width:min(320px,88vw);padding:14px;border-right:1px solid var(--line);color:var(--fg)}
.app-drawer-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 0 12px;border-bottom:1px solid var(--line)}
.app-drawer-header h2{display:flex;align-items:center;gap:8px;margin:0;color:var(--brand-700);font-size:17px;font-weight:800}
.app-drawer-menu{width:100%;padding:12px 0}
.app-drawer-menu :is(summary,.app-drawer-menu-item){display:grid!important;grid-template-columns:20px minmax(0,1fr);align-content:center;align-items:center;gap:10px;min-height:44px;color:var(--fg);font-size:14px;font-weight:800;text-align:left}
.app-drawer-menu :is(summary,.app-drawer-menu-item)>i:first-child{color:currentColor}
.app-view-submenu{gap:4px}
.app-view-option{display:block!important;width:100%;padding:8px 10px!important;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--fg);text-align:left}
.app-view-option:hover,.app-view-option:focus-visible{background:#eef8f3}
.app-view-option.is-active{border-color:#b8dcc8;background:#e9f7ef}
.app-view-option-content{display:grid!important;grid-template-columns:minmax(0,1fr);gap:2px;width:100%;min-width:0;flex:1 1 auto}
.app-view-option-id{display:block;color:var(--muted);font-size:10px;font-weight:700;line-height:1.2}
.app-view-option-main{display:grid!important;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:8px;width:100%;min-width:0}
.app-view-option-name{min-width:0;font-size:14px;font-weight:800;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.app-view-option-description{justify-self:end;max-width:120px;color:#64746d;font-size:11px;font-weight:600;line-height:1.25;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.app-settings-modal{width:min(480px,calc(100vw - 24px));max-height:calc(100dvh - 32px);padding:14px;background:var(--surface)}
.app-settings-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.app-settings-header h2{display:flex;align-items:center;gap:8px;margin:0;color:var(--brand-700);font-size:17px;font-weight:800}
.app-settings-list{display:grid;gap:10px;padding-top:12px}
.app-setting-item{display:grid;gap:9px;padding:12px;border:1px solid var(--line);border-radius:10px;background:var(--surface-soft)}
.app-setting-toggle{grid-template-columns:minmax(0,1fr) auto;align-items:center;cursor:pointer}
.app-setting-copy{display:grid;gap:3px;min-width:0}
.app-setting-title{font-size:13px;font-weight:800;color:var(--fg)}
.app-setting-description{font-size:11px;line-height:1.45;color:var(--muted)}
.app-setting-item .select{font-size:12px;background:var(--surface)}
.app-admin-login-form{display:grid;gap:12px;padding-top:12px}
.app-admin-token-field{display:grid;gap:6px}
.app-admin-token-control{position:relative;display:block}
.app-admin-token-control .input{padding-right:42px;background:var(--surface)}
.app-admin-token-input.is-masked{-webkit-text-security:disc;text-security:disc}
.app-admin-token-control .btn{position:absolute;right:1px;top:50%;transform:translateY(-50%)}
.app-admin-login-status{min-height:20px;margin:10px 0 0;font-size:12px;color:var(--muted)}
.app-admin-login-status.is-success{color:#166534}
.app-admin-login-status.is-error{color:#991b1b}
.app-admin-links{display:grid;gap:10px;padding-top:12px}
.app-admin-links .btn{justify-content:flex-start}

main{display:block;overflow:visible}
.map-panel{position:relative;height:var(--map-panel-height);min-height:0;background:#e9f2ed;border-bottom:1px solid var(--line);overflow:hidden;display:grid;grid-template-rows:auto 0px 0px minmax(0,1fr) auto;transition:height .16s ease,grid-template-rows .16s ease}
body.is-rain-radar-enabled .map-panel{height:calc(var(--map-panel-height) + var(--rain-radar-controls-height));grid-template-rows:auto var(--rain-radar-controls-height) 0px minmax(0,1fr) auto}
body.is-time-simulation-enabled .map-panel{height:calc(var(--map-panel-height) + var(--time-simulation-controls-height));grid-template-rows:auto 0px var(--time-simulation-controls-height) minmax(0,1fr) auto}
.map-container{width:100%;height:100%;min-height:0;touch-action:none}
.map-toolbar{display:flex;justify-content:space-between;align-items:center;gap:6px;padding:6px 8px;z-index:3;background:linear-gradient(180deg,rgba(255,255,255,0.97),rgba(248,253,250,0.82));backdrop-filter:blur(12px);border-bottom:1px solid rgba(43,111,80,0.12);box-shadow:0 6px 18px rgba(31,86,62,0.08);overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
.map-toolbar-left{display:flex;gap:5px;align-items:center;flex:0 0 auto;min-width:0}
.map-toolbar-actions{display:flex;gap:6px;align-items:center;flex:0 0 auto}
.map-label{display:none}
.map-button{gap:4px;font-size:12px;font-weight:700;line-height:1;text-transform:none}
.map-button:hover{text-decoration:none}
.map-button.active{}
.map-button.map-button-off{border-color:#d7ded9 !important;color:#8a9790 !important;background:rgba(255,255,255,0.62) !important}
.map-button.map-button-off:hover{border-color:#c8d2cc !important;color:#69776f !important;background:rgba(255,255,255,0.86) !important}
.youbike-toggle:disabled,.rain-radar-toggle:disabled{opacity:.42;filter:grayscale(1);cursor:not-allowed}
.youbike-toggle,.rain-radar-toggle,.time-simulation-toggle{width:28px;min-width:28px;padding:0}
.rain-radar-controls{display:grid;grid-template-columns:28px minmax(70px,1fr) minmax(82px,auto) auto auto 28px;align-items:center;gap:5px;height:0;min-height:0;box-sizing:border-box;overflow:hidden;padding:0 8px;border-bottom:0 solid rgba(20,91,134,.16);background:linear-gradient(180deg,rgba(240,249,255,.96),rgba(232,246,253,.9));box-shadow:0 4px 12px rgba(14,116,144,.08);z-index:3;white-space:nowrap;opacity:0;transform:translateY(-4px);pointer-events:none;transition:height .16s ease,padding .16s ease,border-bottom-width .16s ease,opacity .12s ease,transform .16s ease}
body.is-rain-radar-enabled .rain-radar-controls{height:var(--rain-radar-controls-height);padding:4px 8px;border-bottom-width:1px;opacity:1;transform:translateY(0);pointer-events:auto}
.time-simulation-controls{display:grid;grid-template-columns:minmax(118px,auto) minmax(90px,1fr) minmax(42px,auto);align-items:center;gap:6px;height:0;min-height:0;box-sizing:border-box;overflow:hidden;padding:0 8px;border-bottom:0 solid rgba(47,125,91,.16);background:linear-gradient(180deg,rgba(245,253,248,.96),rgba(235,248,241,.92));box-shadow:0 4px 12px rgba(31,86,62,.08);z-index:3;white-space:nowrap;opacity:0;transform:translateY(-4px);pointer-events:none;transition:height .16s ease,padding .16s ease,border-bottom-width .16s ease,opacity .12s ease,transform .16s ease}
body.is-time-simulation-enabled .time-simulation-controls{height:var(--time-simulation-controls-height);padding:4px 8px;border-bottom-width:1px;opacity:1;transform:translateY(0);pointer-events:auto}
.time-simulation-date{width:118px;min-height:24px;height:24px;padding:0 6px;border-color:#b8dcc8;background:#fff;color:#174632;font-size:11px;font-weight:800}
.time-simulation-time{width:100%;min-width:90px;height:18px;accent-color:var(--brand-600)}
.time-simulation-label{min-width:42px;color:var(--brand-700);font-size:12px;font-weight:800;line-height:1.15;text-align:right}
.rain-radar-icon-button.btn{width:28px;min-width:28px;padding:0}
.rain-radar-action-button.btn{min-width:38px;padding:0 7px}
.rain-radar-time{width:100%;min-width:70px;height:18px;accent-color:#0ea5e9;--forecast-start:100%;background:linear-gradient(90deg,#bae6fd 0%,#bae6fd var(--forecast-start),#fde68a var(--forecast-start),#fde68a 100%);border-radius:999px}
.rain-radar-time.is-forecast{accent-color:#f59e0b}
.rain-radar-frame-label{min-width:82px;max-width:170px;overflow:hidden;text-overflow:ellipsis;color:#075985;font-size:11px;font-weight:800;line-height:1.15}
.rain-radar-frame-label.is-forecast{color:#92400e}
.rain-radar-arrow-toggle{display:inline-flex;align-items:center;gap:3px;color:#334155;font-size:11px;font-weight:800;line-height:1;cursor:pointer}
.rain-radar-arrow-toggle .toggle{min-height:14px;height:14px;width:24px}
.lwxr-overlay-root{position:absolute;left:0;top:0;z-index:1;pointer-events:none}
.lwxr-overlay-root.is-map-interacting{visibility:hidden}
.lwxr-tile{position:absolute;border:0;padding:0;margin:0;pointer-events:none;user-select:none;image-rendering:auto;transform-origin:0 0}
.map-area-filter{position:relative;display:inline-flex;align-items:center;flex:0 0 auto;color:var(--brand-700)}
.map-area-filter .select{min-width:0;max-width:132px;min-height:28px;height:28px;padding:0 25px 0 9px;border-color:currentColor;background-color:transparent;background-image:none!important;box-shadow:none;outline:0;color:inherit;font-size:12px;font-weight:700;cursor:pointer;appearance:none;-webkit-appearance:none}
.map-area-filter .select:is(:hover,:focus,:focus-visible){border-color:currentColor;background-color:rgba(255,255,255,.86);box-shadow:none;outline:0}
.map-area-filter i{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:9px;color:inherit;pointer-events:none}
.map-area-filter select option{background:#fff;color:#17211c}
.locate-button{flex:0 0 auto}
#locateMe:disabled{opacity:.72;cursor:wait}
.map-center-crosshair{display:none;position:absolute;left:50%;top:50%;width:22px;height:22px;transform:translate(-50%,-50%);z-index:4;pointer-events:none;color:#1f6f50;filter:drop-shadow(0 1px 2px rgba(255,255,255,.95))}
.map-panel.is-reference-selecting .map-center-crosshair{display:block}
.map-center-crosshair::before,.map-center-crosshair::after{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:currentColor;border-radius:999px}
.map-center-crosshair::before{width:22px;height:2px}
.map-center-crosshair::after{width:2px;height:22px}
.map-reference-guide{position:absolute;top:42px;left:50%;z-index:4;max-width:calc(100% - 20px);transform:translateX(-50%);padding:4px 8px;border:1px solid rgba(31,86,62,.28);border-radius:999px;background:rgba(255,255,255,.94);box-shadow:0 2px 8px rgba(31,86,62,.12);color:var(--brand-700);font-size:11px;font-weight:700;line-height:1.35;text-align:center;white-space:nowrap;pointer-events:none}
.map-panel.is-rain-radar-enabled .map-reference-guide,.map-panel.is-time-simulation-enabled .map-reference-guide{top:76px}
.map-status{display:flex;justify-content:space-between;gap:10px;padding:6px 10px;background:rgba(255,255,255,0.98);border-top:1px solid rgba(23,33,28,0.08);font-size:11px;color:#26352d;z-index:3;white-space:nowrap;overflow:hidden}
.map-status > span{overflow:hidden;text-overflow:ellipsis}
.map-status > span:last-child{margin-left:auto;text-align:right}
.error{position:absolute;top:58px;left:10px;right:10px;padding:8px 10px;background:#fff1f1;color:#a31616;border:1px solid #ffd1d1;border-radius:8px;font-size:12px;z-index:3;display:none}
.error:not(:empty){display:block}

.filter-panel{padding:8px 10px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,0.98),rgba(250,254,252,0.97));box-shadow:0 4px 12px rgba(31,86,62,0.06)}
.controls{display:flex;flex-wrap:wrap;gap:6px;align-items:center;color:var(--muted)}
.control-check{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 2px;border:0;background:transparent;font-size:12px;font-weight:700;color:#5f6f68}
.control-check:has(input:checked){color:#47564f}
.control-check input{accent-color:var(--brand-600)}
.control-label-short{display:none}
.sort-wrap{display:inline-flex;align-items:center;gap:5px;height:28px;margin-left:auto;padding:0 2px;color:#5f6f68}
.sort-wrap i{color:#5f6f68}
.sort-wrap select{font-size:12px;font-weight:700;color:#5f6f68}
.filter-options-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:7px}
.chips{display:flex;align-items:center;gap:6px;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.chip{flex:0 0 auto;font-size:11px;font-weight:700;line-height:1;cursor:pointer}
.chip:hover{text-decoration:none}
.chip.badge-primary{font-weight:800}
.user-mark-filters{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex:0 0 auto;margin-left:auto}
.user-mark-filter{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;min-height:0;padding:0;border:0;border-radius:999px;background:transparent;color:#e3e8ef;font-size:20px;line-height:1;cursor:pointer}
.user-mark-filter:hover{text-decoration:none}
.user-mark-filter[data-user-mark-filter="todo"].is-active{color:#2f7fc1}
.user-mark-filter[data-user-mark-filter="favorite"].is-active{color:#d44f5a}
.user-mark-filter[data-user-mark-filter="unvisited"].is-active{color:#2f7d5b}

.place-list{display:flex;flex-direction:column;padding:0;margin:0;list-style:none;overflow:visible;min-height:0;max-height:none;background:var(--bg);border-top:1px solid #d9e2ef}
.list-loading{min-height:100%;display:grid;place-content:center;justify-items:center;gap:10px;color:var(--brand-700);font-size:13px;font-weight:800}
.list-loading .loading{color:var(--brand-600)}
.list-group{list-style:none;margin:0;padding:6px 8px 0}
.list-group-collapse.collapse{overflow:visible;border-radius:8px;background:#fff}
.list-group-title.collapse-title{position:sticky;top:var(--list-sticky-top);z-index:18;display:flex;align-items:center;gap:8px;min-height:36px;padding:8px 36px 8px 10px;background:#fff;box-shadow:0 1px 0 #d9e2ef;font-size:12px;font-weight:800;color:var(--brand-700)}
.list-group-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.list-group-count.badge{margin-left:auto;font-size:10px;font-weight:800}
.list-group-body.collapse-content{padding:0}
.list-group-items{display:flex;flex-direction:column;list-style:none;margin:0;padding:0}
.list-group-items .place-row:last-child{border-bottom:0}
.place-row{position:relative;display:grid;grid-template-columns:82px minmax(0,1fr) auto;gap:4px 8px;padding:8px 10px;border-top:0;border-bottom:1px solid #d9e2ef;border-radius:0;background:#fff;color:#172033;overflow:hidden;touch-action:pan-y;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
.place-row+.place-row{border-top:0}
.place-row:hover{background:#fbfdff}
.place-row.selected{background:#f0f9ff;border-left:4px solid #60a5fa;padding-left:6px}
.place-row.is-closed{background:#fff;color:#56616f}
.place-row.is-user-hidden{background:#f3f4f6;color:#5f6875}
.place-row.is-user-hidden .name,.place-row.is-user-hidden .rating-score,.place-row.is-user-hidden .distance{color:#4b5563}
.place-row.is-user-hidden .category-badge,.place-row.is-user-hidden .tag,.place-row.is-user-hidden .row-actions .btn,.place-row.is-user-hidden .external-link{opacity:.72}
.hours-col{grid-row:1 / 4;display:grid;align-content:start;gap:4px;min-width:0;padding-right:8px;border-right:1px solid rgba(217,226,239,.7)}
.today-hours{white-space:pre-line;text-align:center;font-size:10px;font-weight:700;line-height:1.25;color:#2f5f9f}
.place-row.is-closed .today-hours{color:#56616f}
.place-row .status-badge{display:inline-flex;align-items:center;justify-content:center;width:100%;height:20px;border-radius:999px;padding:0 4px;font-size:11px;font-weight:700;line-height:1;white-space:nowrap}
.place-row .status-badge.status--open{background:#16a34a;color:#fff}
.place-row .status-badge.status--open.status--closing-soon{background:#f59e0b;color:#422006}
.place-row .status-badge.status--open.status--closing-urgent{background:#dc2626;color:#fff}
.place-row .status-badge.status--closed{background:#111827;color:#fff}
.place-row .status-badge.status--permanently-closed{background:#991b1b;color:#fff}
.place-row .status-badge.status--before{border:1px solid #c9daf7;background:#e8f1ff;color:#2f5f9f}
.place-row .status-badge.status--break{border:1px solid #ead4ad;background:#fff3dc;color:#8a5a16}
.place-row .remaining-time{text-align:center;font-size:12px;font-weight:700;line-height:1;color:#64748b;white-space:nowrap}
.place-row.status--open .remaining-time{color:#15803d}
.place-row.status--before .remaining-time{color:#2f5f9f}
.place-row.status--break .remaining-time{color:#8a5a16}
.place-row .remaining-time.remaining-time--urgent,.modal-card .remaining-time.remaining-time--urgent{color:#dc2626}
.place-row .remaining-time.remaining-time--soon,.modal-card .remaining-time.remaining-time--soon{color:#16a34a}
.place-title-row{display:flex;align-items:center;gap:6px;min-width:0;line-height:1}
.category-badge-list{display:inline-flex;align-items:center;gap:4px;flex:0 1 auto;min-width:0;max-width:100%;overflow:hidden}
.category-badge{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;min-width:0;height:20px;border:1px solid transparent;border-radius:999px;padding:0 6px;font-size:10px;font-weight:800;line-height:1;white-space:nowrap}
.category--ice{border-color:#bae6fd;background:#f0f9ff;color:#0369a1}
.category--dumpling{border-color:#fde68a;background:#fffbeb;color:#b45309}
.category--soy{border-color:#a7f3d0;background:#ecfdf5;color:#047857}
.category--noodle{border-color:#fed7aa;background:#fff7ed;color:#c2410c}
.category--mee{border-color:#ddd6fe;background:#f5f3ff;color:#6d28d9}
.category--sweet{border-color:#fbcfe8;background:#fdf2f8;color:#be185d}
.category--cafe{border-color:#e7d1a6;background:#fdf8ed;color:#8a6f3f}
.category--default{border-color:#cbd5e1;background:#fbfdff;color:#475569}
.name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:800;color:#071225;letter-spacing:0}
.tags{grid-column:2 / 4;display:flex;gap:8px;flex-wrap:wrap;min-width:0;overflow:hidden;white-space:nowrap}
.tag{display:inline-flex;align-items:center;height:18px;border:1px solid #cbd5e1;border-radius:999px;background:transparent;padding:0 6px;color:#475569;font-size:10px;font-weight:700;line-height:1;white-space:nowrap}
.tag--break{border-color:#f1d19b;color:#8a5a16}
.tag--early{border-color:#bae6fd;color:#0369a1}
.tag--late{border-color:#cbd5e1;color:#475569}
.tag--tomorrow{border-color:#fca5a5;background:#fee2e2;color:#b91c1c}
.tag--tomorrow-consecutive{border-color:#dc2626;background:#dc2626;color:#fff}
.tag-line .tag--tomorrow{color:#b91c1c}
.tag-line .tag--tomorrow-consecutive{color:#fff}
.tag--inactive-today{border-color:#e5e7eb;background:transparent;color:#cbd5e1}
.place-row .meta-row{grid-column:2 / 4;display:flex;align-items:center;gap:8px;min-width:0;font-size:12px;line-height:1.25;color:#667085}
.area-station{min-width:0;flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.list-rating{display:inline-flex;align-items:center;gap:1px;flex:0 0 auto;font-size:12px;font-weight:800;line-height:1;color:#0f1f3a;white-space:nowrap}
.rating-star{color:#f59f39}
.rating-score{color:#0f1f3a}
.distance{flex:0 0 auto;font-size:12px;font-weight:800;color:#0f1f3a;white-space:nowrap}
.external-link{display:inline-flex;align-items:center;justify-content:center;color:#50627d;text-decoration:none;font-size:20px}
.row-actions{display:flex;align-items:center;gap:6px;color:#64748b}
.hidden-status-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;flex:0 0 auto;color:#c05621;font-size:18px;line-height:1}
.row-actions .btn{width:20px;height:20px;min-height:0;padding:0;border-radius:999px;font-size:20px;color:#e3e8ef}
.row-actions .btn.is-active{color:#2f5f9f}
.row-actions .visited-btn.is-active{color:#2f7d5b}
.row-actions .favorite-btn.is-active{color:#d44f5a}
.row-actions .todo-btn.is-active{color:#2f7fc1}
.row-actions .external-link{width:28px;height:28px;min-height:0;padding:0;border-radius:8px;color:#50627d}
.row-hide-action{position:absolute;top:0;right:0;bottom:0;z-index:3;display:flex;align-items:center;justify-content:center;width:78px;border:0;border-radius:0;background:#dc2626;color:#fff;font-size:13px;font-weight:900;line-height:1;transform:translateX(100%);transition:transform .16s ease;background-clip:padding-box}
.row-hide-action.is-restore{background:#16a34a}
.place-row.is-swipe-open .row-hide-action{transform:translateX(0)}
[hidden]{display:none!important}

.current-location-overlay,.distance-reference-overlay{position:absolute;inset:0;pointer-events:none}
.shop-marker{--marker-bg:#f3faf6;--marker-border:#b9dfca;--marker-icon:#2f7d5b;position:relative;display:flex;align-items:center;gap:6px;min-width:104px;max-width:176px;padding:6px 9px 6px 7px;border-radius:999px;background:linear-gradient(180deg,#fff,var(--marker-bg));border:1px solid var(--marker-border);box-shadow:0 3px 10px rgba(23,33,28,.18);color:#1f2933;font-size:12px;font-weight:700;line-height:1.2;white-space:nowrap;cursor:pointer;transform:translateY(-6px);transition:transform 140ms ease,box-shadow 140ms ease,border-color 140ms ease}
.shop-marker:not(.has-user-icon){min-width:0;padding-left:9px}
.shop-marker::after{content:"";position:absolute;left:50%;bottom:-6px;width:10px;height:10px;background:var(--marker-bg);border-right:1px solid var(--marker-border);border-bottom:1px solid var(--marker-border);transform:translateX(-50%) rotate(45deg);box-shadow:3px 3px 5px rgba(23,33,28,.08)}
.shop-marker:hover,.shop-marker.is-active{transform:translateY(-10px) scale(1.06);box-shadow:0 7px 18px rgba(23,33,28,.24);border-color:var(--marker-icon);z-index:2}
.shop-icon{display:grid;place-items:center;flex:0 0 24px;width:24px;height:24px;color:var(--brand-600);font-size:20px;line-height:1}
.shop-icon--todo{color:#2f7fc1}
.shop-icon--favorite{color:#d44f5a}
.shop-icon--visited{color:#2f7d5b}
.shop-name{display:block;min-width:0;flex:1 1 auto;overflow:hidden;text-overflow:ellipsis}
.shop-meta{display:flex;align-items:center;justify-content:flex-start;gap:4px;margin-top:1px;color:#666;font-size:10px;font-weight:700;line-height:1;min-height:12px}
.shop-status.status-badge{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;height:12px;border-radius:999px;padding:0 4px;font-size:9px;font-weight:800;line-height:1;white-space:nowrap}
.shop-status.status--open{background:#16a34a;color:#fff}
.shop-status.status--open.status--closing-soon{background:#f59e0b;color:#422006}
.shop-status.status--open.status--closing-urgent{background:#dc2626;color:#fff}
.shop-status.status--closed{background:#111827;color:#fff}
.shop-status.status--permanently-closed{background:#991b1b;color:#fff}
.shop-status.status--before{border:1px solid #c9daf7;background:#e8f1ff;color:#2f5f9f}
.shop-status.status--break{border:1px solid #ead4ad;background:#fff3dc;color:#8a5a16}
.shop-rating{display:inline-flex;align-items:center;gap:1px;flex:0 0 auto;font-weight:800;color:#0f1f3a}
.shop-marker.restaurant{--marker-bg:#fff7ed;--marker-border:#fed7aa;--marker-icon:#ea580c}
.shop-marker.cafe{--marker-bg:#fdf8ed;--marker-border:#e7d1a6;--marker-icon:#8a6f3f}
.shop-marker.bakery{--marker-bg:#fdf2f8;--marker-border:#fbcfe8;--marker-icon:#cf5c7c}
.shop-marker.bar{--marker-bg:#f5f3ff;--marker-border:#ddd6fe;--marker-icon:#7c3aed}
.shop-marker.default{--marker-bg:#eff6ff;--marker-border:#bfdbfe;--marker-icon:#2563eb}
.cluster-marker{position:relative;display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:999px;background:#f59f39;color:#fff;border:4px solid rgba(255,255,255,.95);box-shadow:0 5px 18px rgba(23,33,28,.28);font-weight:900;text-align:center;line-height:1.05;cursor:pointer}
.cluster-marker::before{content:"";position:absolute;inset:-8px;border-radius:999px;background:rgba(245,159,57,.20)}
.cluster-marker .count{position:relative;z-index:1;display:block;font-size:18px}
.cluster-marker .label{position:relative;z-index:1;display:block;margin-top:2px;font-size:10px;opacity:.95}
.cluster-marker.is-large{width:66px;height:66px}
.cluster-marker.is-large .count{font-size:21px}
.youbike-station-marker{position:relative;transform:translateY(-6px);display:inline-flex;align-items:center;height:17px;padding:1px 3px;border-radius:999px;border:1px solid rgba(22,101,52,.55);background:rgba(220,252,231,.94);color:#14532d;box-shadow:0 1px 4px rgba(15,23,42,.20);font-size:11px;line-height:1;font-weight:900;letter-spacing:0;white-space:nowrap;user-select:none;cursor:pointer}
.youbike-station-marker.return-ng{border-color:rgba(249,115,22,.78);background:rgba(254,215,170,.97);color:#9a3412}
.youbike-station-marker.rent-ng{border-color:rgba(220,38,38,.72);background:rgba(254,202,202,.97);color:#7f1d1d}
.youbike-station-marker.inactive{border-color:rgba(75,85,99,.55);background:rgba(229,231,235,.92);color:#4b5563;opacity:.75;filter:grayscale(.45)}
.youbike-station-marker::after{content:"";position:absolute;left:50%;bottom:-5px;width:0;height:0;transform:translateX(-50%);border-left:4px solid transparent;border-right:4px solid transparent;border-top:6px solid rgba(220,252,231,.94);filter:drop-shadow(0 1px 1px rgba(15,23,42,.20))}
.youbike-station-marker.return-ng::after{border-top-color:rgba(254,215,170,.97)}
.youbike-station-marker.rent-ng::after{border-top-color:rgba(254,202,202,.97)}
.youbike-station-marker.inactive::after{border-top-color:rgba(229,231,235,.92)}
.youbike-bike-count,.youbike-return-count{min-width:0;text-align:center}
.youbike-ebike-icon{margin-left:1px;color:#f97316;font-size:9px}
.youbike-sep{margin:0 1px;color:rgba(15,23,42,.48);font-weight:900}
.youbike-station-marker.return-ng .youbike-sep{color:rgba(194,65,12,.48)}
.youbike-station-marker.rent-ng .youbike-sep{color:rgba(127,29,29,.42)}
.youbike-popup{display:grid;gap:7px;min-width:160px;max-width:240px;color:#111827;font-size:13px}
.youbike-popup-main{font-size:15px;font-weight:900}
.youbike-popup-detail{display:inline-flex;gap:8px;margin-left:8px;vertical-align:middle}
.youbike-popup-bike{display:inline-flex;align-items:center;gap:3px;color:#374151;font-weight:800}
.youbike-popup-ebike{display:inline-flex;align-items:center;gap:3px;color:#f97316;font-weight:900}
.youbike-popup-return{font-size:15px;font-weight:900;color:#166534}
.youbike-popup-return.is-empty{color:#c2410c}
.youbike-popup-warning{font-size:12px;color:#991b1b;font-weight:800}
.current-location-accuracy{position:absolute;transform:translate(-50%,-50%);background:rgba(26,115,232,0.12);border:1px solid rgba(26,115,232,.22);border-radius:999px;pointer-events:none}
.current-location-dot{position:absolute;transform:translate(-50%,-50%);width:18px;height:18px;border-radius:50%;background:#1a73e8;border:3px solid #fff;box-shadow:0 0 0 8px rgba(26,115,232,0.18),0 2px 9px rgba(0,0,0,0.3)}
.distance-reference-marker{position:absolute;transform:translate(-50%,-100%);width:24px;height:24px;border-radius:999px;background:#1f6f50;border:3px solid #fff;box-shadow:0 2px 8px rgba(23,33,28,0.32),0 0 0 5px rgba(31,111,80,0.18)}
.distance-reference-marker::before{content:'';position:absolute;left:50%;bottom:-9px;width:12px;height:12px;background:#1f6f50;border-right:3px solid #fff;border-bottom:3px solid #fff;transform:translateX(-50%) rotate(45deg);box-shadow:3px 3px 6px rgba(23,33,28,0.18)}
.distance-reference-marker::after{content:'';position:absolute;left:50%;top:50%;width:7px;height:7px;border-radius:999px;background:#fff;transform:translate(-50%,-50%)}

.app-toast.toast{top:12px;left:auto;right:12px;bottom:auto;z-index:90;width:min(420px,calc(100vw - 24px));padding:0;transform:translateX(calc(100% + 16px));opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,transform .18s ease,visibility .18s}
.app-toast.is-visible{transform:translateX(0);opacity:1;visibility:visible;pointer-events:auto;cursor:pointer}
.app-toast-alert.alert{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:start;width:100%;padding:12px 14px;border:1px solid;box-shadow:0 8px 24px rgba(23,33,28,.18);color:#17211c}
.app-toast-alert>i{margin-top:2px;font-size:18px}
.app-toast-alert.alert-info{border-color:#9bc7dc;background:#edf8fc}
.app-toast-alert.alert-info>i{color:#146c94}
.app-toast-alert.alert-success{border-color:#9bcdb3;background:#eef9f2}
.app-toast-alert.alert-success>i{color:var(--brand-700)}
.app-toast-alert.alert-warning{border-color:#e7b963;background:#fff7df}
.app-toast-alert.alert-warning>i{color:#a16207}
.app-toast-alert.alert-error{border-color:#e5a09a;background:#fff0ee}
.app-toast-alert.alert-error>i{color:#b42318}
.app-toast-title{font-size:14px;font-weight:800;line-height:1.35}
.app-toast-message{margin-top:2px;font-size:12px;line-height:1.45;color:#425048}
.app-toast-action{margin-top:8px;border:0;background:transparent;color:#14532d;padding:0;font-size:13px;font-weight:900;text-decoration:underline;text-underline-offset:3px;cursor:pointer}

.modal-overlay{position:fixed;inset:0;background:rgba(11,15,12,0.32);display:flex;align-items:flex-end;justify-content:center;padding:12px 10px;z-index:60;overflow:hidden}
.modal-card{position:relative;background:linear-gradient(180deg,#fff,#fbfefc);border-radius:16px;width:min(480px, calc(100vw - 20px));min-width:0;min-height:0;max-height:calc(100dvh - 24px);box-shadow:0 18px 38px rgba(23,33,28,0.20);padding:0;border:1px solid rgba(43,111,80,0.16);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}
.modal-card.modal-destination{width:min(520px, calc(100vw - 20px));min-width:0;min-height:0;text-align:center}
.modal-close-x{position:absolute;top:10px;right:10px;z-index:2;color:var(--brand-700)}
.modal-close-x:hover{background:#f3faf6}
.modal-header{display:flex;flex-direction:column;gap:4px;padding:12px 14px 10px;border-bottom:1px solid #e4efe8;background:linear-gradient(180deg,#fff,#f4fbf7)}
.detail-modal-header{background:#fff}
.detail-header-top{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:flex-start;gap:10px;width:100%}
.top-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.header-main{display:flex;flex:1 1 auto;min-width:0;flex-direction:column;gap:5px}
.header-actions{display:flex;gap:5px;align-items:flex-start;flex:0 0 auto}
.detail-header-actions{margin-right:44px}
.detail-header-actions.row-actions .btn{width:22px;height:22px;font-size:20px}
.header-actions .modal-close-x.btn{position:static;width:24px;height:24px;min-height:0;border-radius:999px;font-size:18px}
.icon-btn{background:#fff;border:1px solid var(--line);width:32px;height:32px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;color:var(--brand-600);cursor:pointer;box-shadow:0 1px 3px rgba(31,86,62,0.06)}
.status-row{display:grid;grid-template-columns:auto auto auto;justify-content:start;gap:6px 14px;align-items:center;width:100%;min-width:0}
.status-row .remaining-time{font-size:12px;font-weight:700;line-height:1;color:#64748b;white-space:nowrap}
.status-row .remaining-time.remaining-time--open{color:#15803d}
.status-row .remaining-time.remaining-time--before{color:#2f5f9f}
.status-row .remaining-time.remaining-time--break{color:#8a5a16}
.place-row .remaining-time.remaining-time--closing-soon,.modal-card .status-row .remaining-time.remaining-time--closing-soon{color:#b45309}
.modal-card .status-row .remaining-time.remaining-time--urgent{color:#dc2626}
.status-row .today-hours-detail{min-width:0;text-align:left}
.modal-card .status-badge{display:inline-flex;align-items:center;justify-content:center;height:20px;border-radius:999px;padding:0 8px;font-size:11px;font-weight:800;line-height:1;white-space:nowrap}
.modal-card .status-badge.status--open{background:#16a34a;color:#fff}
.modal-card .status-badge.status--open.status--closing-soon{background:#f59e0b;color:#422006}
.modal-card .status-badge.status--open.status--closing-urgent{background:#dc2626;color:#fff}
.modal-card .status-badge.status--closed{background:#111827;color:#fff}
.modal-card .status-badge.status--permanently-closed{background:#991b1b;color:#fff}
.modal-card .status-badge.status--before{border:1px solid #c9daf7;background:#e8f1ff;color:#2f5f9f}
.modal-card .status-badge.status--break{border:1px solid #ead4ad;background:#fff3dc;color:#8a5a16}
.category-row,.subtitle-row,.meta-row{font-size:12px;color:var(--muted)}
.category-row{display:flex;align-items:center;gap:6px;min-width:0}
.category-row .category-badge{height:18px}
.category-row .rating{display:inline-flex;align-items:center;font-weight:900;color:#0f1f3a;line-height:1}
.category-row .rating::before{content:'★';color:#f59f39;margin-right:2px}
.place-name{display:flex;align-items:center;gap:5px;min-width:0;font-size:17px;margin:0;font-weight:900;color:var(--brand-700);line-height:1.22}
.place-name [data-name]{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.place-name .external-link{flex:0 0 auto;font-size:17px;color:#50627d}
.today-hours-detail{font-size:15px;font-weight:900;line-height:1.25;color:var(--brand-700);overflow-wrap:anywhere}
.tag-line{display:flex;flex-wrap:wrap;gap:5px}
.tag-line .tag--tomorrow{color:#b91c1c}
.tag-line .tag--tomorrow-consecutive{color:#fff}
.tag-line .tag--inactive-today{border-color:#e5e7eb;background:transparent;color:#cbd5e1}
.detail-features{font-size:12px;font-weight:800;color:#0f1f3a;line-height:1.4}
.detail-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,0.85fr);gap:10px;margin-top:10px;min-width:0}
.detail-body{display:flex;flex-direction:column;gap:8px;padding:10px 12px 12px}
.detail-column{display:flex;flex-direction:column;gap:10px;min-width:0}
.section-card{background:rgba(251,254,252,0.96);border:1px solid var(--line);border-radius:8px;padding:9px;display:flex;flex-direction:column;gap:7px;box-shadow:0 1px 2px rgba(31,86,62,0.04);min-width:0}
.section-heading{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:900;color:var(--brand-700)}
.section-body{display:flex;flex-direction:column;gap:8px}
.location-main{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;min-width:0}
.location-content{display:flex;flex-direction:column;gap:7px;min-width:0}
.location-area-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--brand-700);font-size:12px;line-height:1.35}
.location-address{color:var(--muted);font-size:12px;line-height:1.35}
.address-button{align-self:center;gap:6px;font-size:12px;font-weight:700;text-transform:none;white-space:nowrap}
.field-label{color:var(--muted);font-size:11px}
.field-value{font-weight:800;color:var(--brand-700);text-decoration:none}
.info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
.info-item{display:flex;flex-direction:column;gap:3px}
.user-note-field{display:flex;flex-direction:column;gap:5px}
.user-note-input{width:100%;min-height:48px;resize:vertical;border:1px solid var(--line);border-radius:8px;background:#fff;padding:7px 8px;color:var(--brand-700);font-size:12px;line-height:1.45}
.user-note-input:focus{outline:2px solid #c7e5d4;outline-offset:1px}
.user-note-privacy{font-size:10px;font-weight:500;color:var(--muted)}
.hours-table{width:100%;font-size:12px}
.hours-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:3px 10px}
.hours-column{display:flex;flex-direction:column;gap:3px;min-width:0}
.hours-row{display:grid;grid-template-columns:2.1rem minmax(0,1fr);gap:6px;align-items:center;min-width:0;border-radius:7px;padding:3px 6px}
.hours-row.today-row{background:#e3f3ea;color:var(--brand-700);font-weight:900}
.hours-row.closed{color:#b42318;font-weight:800}
.hours-day{font-weight:800}
.hours-time{min-width:0;white-space:pre-line;line-height:1.35}
.reference-list{display:flex;flex-direction:column;gap:6px}
.reference-list a{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0;padding:6px 26px 6px 8px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--brand-700);text-decoration:none;font-size:12px;overflow-wrap:anywhere;word-break:break-word}
.reference-list a::after{content:'\f35d';position:absolute;top:50%;right:8px;transform:translateY(-50%);font-family:"Font Awesome 6 Free";font-weight:900;font-size:10px;opacity:.7}
.reference-title{font-weight:800}
.reference-url{color:var(--muted);font-size:11px;font-weight:400}
.note{font-size:12px;color:var(--muted);white-space:pre-wrap}
.admin-note{display:flex;flex-direction:column;gap:3px}
.other-info{gap:8px}
.other-info>summary{cursor:pointer;list-style:none}
.other-info>summary::-webkit-details-marker{display:none}
.detail-tel[href]{display:inline-flex;align-items:center;gap:6px;font-size:12px}
.modal-actions{display:flex;justify-content:flex-end;margin-top:10px}
.btn-close{font-size:12px;font-weight:700;color:var(--brand-700);text-transform:none}
.destination-content{display:flex;flex-direction:column;gap:22px;padding:54px 18px 20px;min-width:0}
.dest-address,.dest-name{font-size:28px;font-weight:900;line-height:1.35;overflow-wrap:anywhere;word-break:break-word}
.dest-address{color:#111}
.dest-name{color:var(--brand-700)}
.destination-actions{padding:0 18px 16px}
.detail-header-actions.row-actions .admin-edit-button.btn{width:auto;min-width:52px;min-height:26px;height:26px;padding:0 8px;border-radius:7px;color:var(--brand-700);font-size:11px;text-transform:none}
.admin-edit-overlay{z-index:90}
.admin-edit-modal{display:flex;flex-direction:column;min-height:0}
.admin-edit-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);background:var(--surface)}
.admin-edit-header h2{margin:2px 0 0;color:var(--brand-700);font-size:18px;font-weight:900}
.admin-edit-eyebrow{color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.08em}
.admin-edit-form{min-height:0;overflow-y:auto;padding:14px 16px 0;background:var(--surface-soft)}
.admin-edit-section{display:grid;gap:10px;margin-bottom:14px;padding:13px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}
.admin-edit-section h3{display:flex;align-items:center;gap:7px;margin:0;color:var(--fg);font-size:14px;font-weight:900}
.admin-edit-section h3 i{color:var(--brand-600)}
.admin-edit-section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.admin-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px 12px}
.admin-edit-field{display:grid;align-content:start;gap:5px;min-width:0;color:#33443b;font-size:12px;font-weight:800}
.admin-edit-field-wide{grid-column:1/-1}
.admin-edit-field :is(.input,.textarea){width:100%;font-size:13px;font-weight:500;background:#fff}
.admin-edit-field .textarea{resize:vertical}
.required-mark{color:#b42318;font-size:10px}
.admin-edit-help{margin:0;color:var(--muted);font-size:11px;line-height:1.45}
.admin-category-options{display:flex;flex-wrap:wrap;gap:7px}
.admin-category-option{min-height:28px;height:28px;padding:0 10px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted);font-size:12px;font-weight:800;cursor:pointer}
.admin-category-option.is-selected{border-color:var(--brand-600);background:#e3f3ea;color:var(--brand-700)}
.admin-inline-add{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}
.admin-reference-rows{display:grid;gap:9px}
.admin-reference-row{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.4fr) auto;gap:8px;align-items:center}
.admin-reference-row :is(.input){width:100%;font-size:12px;background:#fff}
.admin-reference-remove.btn{min-height:32px;height:32px;width:32px;padding:0;color:#991b1b}
.admin-edit-actions{position:sticky;bottom:0;display:flex;justify-content:flex-end;gap:8px;margin:0 -16px;padding:12px 16px;border-top:1px solid var(--line);background:rgba(255,255,255,.96);backdrop-filter:blur(8px)}

@media (max-width:720px){
  .modal-overlay{align-items:flex-start;padding:calc(env(safe-area-inset-top, 0px) + 8px) 8px 8px}
  .modal-card{width:100%;max-width:calc(100vw - 16px);max-height:calc(100dvh - env(safe-area-inset-top, 0px) - 16px);min-height:0;border-radius:14px}
  .detail-grid{grid-template-columns:minmax(0,1fr)}
}
.map-button.btn{min-height:28px;height:28px;text-transform:none}
.control-check .checkbox{width:18px;height:18px;min-height:18px;border-radius:6px;background:#fff;border-color:#cfd8d3;--chkbg:#fff;--chkfg:#17211c}
.sort-wrap .select{
  min-height:28px;
  height:28px;
  padding:0 22px 0 0;
  border:0;
  background-color:transparent;
  box-shadow:none;
  outline:0;
  font-size:12px;
  font-weight:700;
  color:#5f6f68;
}
.sort-wrap .select:is(:hover,:focus,:focus-visible){
  border:0;
  background-color:transparent;
  box-shadow:none;
  outline:0;
  color:#5f6f68;
}
.sort-wrap .select option{
  background-color:#fff;
  color:#17211c;
}
.icon-btn.btn{min-height:32px;height:32px;padding:0}
.address-button.btn{min-height:28px;height:28px;text-transform:none}
.btn-close.btn{min-height:30px;height:30px;padding:7px 10px;text-transform:none}
.modal-overlay.modal{background:rgba(11,15,12,0.32)}
.modal-card.modal-box{width:min(480px, calc(100vw - 20px));max-width:calc(100vw - 20px);padding:0}
.modal-card.modal-box.modal-destination{width:min(520px, calc(100vw - 20px));max-width:calc(100vw - 20px)}
.modal-card.modal-box.admin-edit-modal{width:min(720px, calc(100vw - 20px));max-width:calc(100vw - 20px)}
.modal-card.modal-box.modal-alert{width:min(360px, calc(100vw - 20px));min-height:0;text-align:center}
.modal-alert-body{font-size:15px;font-weight:800;color:#991b1b}
.modal-close-x.btn{min-height:32px;height:32px;width:32px;padding:0;border-color:var(--line);background:#fff;font-size:18px;font-weight:700;box-shadow:0 1px 3px rgba(31,86,62,0.08)}
.modal-close-x.btn:hover{background:#f3faf6}

.filter-profile-panel{position:fixed;left:8px;right:8px;bottom:8px;z-index:80;display:flex;flex-direction:column;gap:6px;padding:8px;border:1px solid #94a3b8;border-radius:8px;background:rgba(15,23,42,.96);color:#f8fafc;box-shadow:0 8px 24px rgba(15,23,42,.26)}
.filter-profile-title{font-size:12px;font-weight:800;line-height:1}
.filter-profile-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.filter-profile-actions button{height:28px;padding:0 10px;border:1px solid #cbd5e1;border-radius:6px;background:#f8fafc;color:#0f172a;font-size:12px;font-weight:800}
.filter-profile-panel textarea{width:100%;height:210px;min-height:120px;border:1px solid #475569;border-radius:6px;padding:8px;background:#020617;color:#e2e8f0;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:11px;line-height:1.35;resize:vertical}

.control-check .checkbox:checked{background:#fff;border-color:#cfd8d3;color:#17211c}
.control-check .checkbox:focus-visible{outline:2px solid #c7e5d4;outline-offset:2px}

@media (max-width:720px){
  .modal-card.modal-box{width:100%;max-width:calc(100vw - 16px)}
  .modal-card.modal-box.modal-destination{width:100%;max-width:calc(100vw - 16px)}
  .modal-card.modal-box.admin-edit-modal{width:100%;max-width:calc(100vw - 16px)}
  .youbike-station-marker{height:16px;padding:1px 3px;font-size:10px}
  .youbike-ebike-icon{font-size:8px}
  .admin-reference-row{grid-template-columns:minmax(0,1fr) auto}
  .admin-reference-row [data-reference-url]{grid-column:1/2}
  .admin-reference-remove{grid-column:2;grid-row:1/3}
  .control-label-full{display:none}
  .control-label-short{display:inline}
  .map-toolbar{align-items:center}
  .map-toolbar-actions{justify-content:flex-start}
  .rain-radar-controls{grid-template-columns:28px minmax(58px,1fr) minmax(66px,auto) auto auto 28px;gap:4px;padding-left:6px;padding-right:6px}
  .time-simulation-controls{grid-template-columns:minmax(106px,auto) minmax(68px,1fr) minmax(38px,auto);gap:4px;padding-left:6px;padding-right:6px}
  .time-simulation-date{width:106px;font-size:10px}
  .time-simulation-label{min-width:38px;font-size:11px}
  .rain-radar-frame-label{max-width:112px;font-size:10px}
  .rain-radar-action-button.btn{min-width:34px;padding:0 5px}
}


/* YouBike InfoWindow */
.gm-style .gm-style-iw-c:has(.youbike-popup){
  padding:0 !important;
  border-radius:10px !important;
}

.gm-style .gm-style-iw-c:has(.youbike-popup) .gm-style-iw-ch{
  padding-top:0 !important;
}

.gm-style .gm-style-iw-d:has(.youbike-popup){
  overflow:hidden !important;
  max-height:none !important;
}

.gm-style .gm-style-iw-c:has(.youbike-popup) button.gm-ui-hover-effect{
  display:none !important;
}

.youbike-popup{
  display:grid;
  gap:4px;
  min-width:0;
  max-width:180px;
  padding:6px 8px;
  color:#111827;
  font-size:12px;
  line-height:1.2;
}

.youbike-popup-row{
  display:flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
}

.youbike-popup-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:22px;
  padding:0 8px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  line-height:1;
}

.youbike-popup-badge.is-ok{
  background:#dcfce7;
  color:#166534;
}

.youbike-popup-badge.is-empty{
  background:#fee2e2;
  color:#991b1b;
}

.youbike-popup-detail{
  display:inline-flex;
  align-items:center;
  gap:7px;
}

.youbike-popup-bike,
.youbike-popup-ebike{
  display:inline-flex;
  align-items:center;
  gap:3px;
  font-size:13px;
  font-weight:900;
}

.youbike-popup-bike{
  color:#166534;
}

.youbike-popup-ebike{
  color:#f97316;
}

.youbike-popup-bike.is-zero,
.youbike-popup-ebike.is-zero{
  color:#9ca3af;
}

.youbike-popup-warning{
  margin-top:1px;
  color:#991b1b;
  font-size:11px;
  font-weight:800;
}
