/* ═══════════════════════════════════════════
   GT Measure Pro — Measurement Tool Styles
   ═══════════════════════════════════════════ */

:root {
    --gtmp-primary: #1B2A4A;
    --gtmp-accent: #C9A84C;
    --gtmp-bg: #F6F5F1;
    --gtmp-card: #FFFFFF;
    --gtmp-text: #1A1D23;
    --gtmp-text2: #535962;
    --gtmp-text3: #8B919A;
    --gtmp-border: #E2DFD8;
    --gtmp-r: 10px;
    --gtmp-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.gtmp-wrap { max-width: 1100px; margin: 32px auto; font-family: var(--gtmp-font); color: var(--gtmp-text); }
.gtmp-wrap * { box-sizing: border-box; }

/* ── Toolbar ── */
.gtmp-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 12px 16px; background: var(--gtmp-card); border: 1px solid var(--gtmp-border); border-radius: var(--gtmp-r) var(--gtmp-r) 0 0; flex-wrap: wrap; }
.gtmp-toolbar-left { flex: 1; min-width: 250px; }
.gtmp-search-box { display: flex; align-items: center; gap: 8px; background: var(--gtmp-bg); border: 1px solid var(--gtmp-border); border-radius: 8px; padding: 4px 4px 4px 12px; }
.gtmp-search-icon { color: var(--gtmp-text3); flex-shrink: 0; }
.gtmp-search-box input { flex: 1; border: none; background: transparent; font-size: 14px; font-family: var(--gtmp-font); color: var(--gtmp-text); outline: none; padding: 6px 0; min-width: 0; }
.gtmp-search-btn { background: var(--gtmp-primary); color: #fff; border: none; border-radius: 6px; padding: 8px 16px; font-size: 13px; font-weight: 700; font-family: var(--gtmp-font); cursor: pointer; white-space: nowrap; transition: background 0.2s; }
.gtmp-search-btn:hover { background: #2A4166; }

.gtmp-tool-group { display: flex; gap: 6px; }
.gtmp-tool-btn { display: flex; align-items: center; gap: 5px; padding: 8px 14px; border: 2px solid var(--gtmp-border); border-radius: 8px; background: var(--gtmp-card); font-size: 12px; font-weight: 700; font-family: var(--gtmp-font); color: var(--gtmp-text); cursor: pointer; transition: all 0.2s; white-space: nowrap; }
.gtmp-tool-btn:hover { border-color: var(--gtmp-primary); color: var(--gtmp-primary); }
.gtmp-tool-btn.active { border-color: var(--gtmp-primary); background: var(--gtmp-primary); color: #fff; }
.gtmp-tool-btn svg { flex-shrink: 0; }
.gtmp-tool-delete { color: #C53030; }
.gtmp-tool-delete:hover { border-color: #C53030; background: #C53030; color: #fff; }

/* ── Map ── */
.gtmp-map-container { position: relative; border-left: 1px solid var(--gtmp-border); border-right: 1px solid var(--gtmp-border); }
#gtmp-map { width: 100%; min-height: 400px; background: #222; z-index: 1; }
.gtmp-map-container .leaflet-container { font-family: var(--gtmp-font); }

/* ── Layer Label Selector ── */
.gtmp-layer-selector { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 1000; background: var(--gtmp-card); border: 1px solid var(--gtmp-border); border-radius: 12px; padding: 20px; box-shadow: 0 8px 32px rgba(0,0,0,0.2); text-align: center; min-width: 300px; }
.gtmp-layer-selector p { font-size: 14px; font-weight: 700; color: var(--gtmp-primary); margin: 0 0 12px; }
.gtmp-label-options { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.gtmp-label-btn { padding: 10px 8px; border: 2px solid var(--gtmp-border); border-radius: 8px; background: var(--gtmp-card); font-size: 12px; font-weight: 600; font-family: var(--gtmp-font); cursor: pointer; transition: all 0.2s; }
.gtmp-label-btn:hover { border-color: var(--gtmp-primary); background: rgba(27,42,74,0.04); transform: translateY(-1px); }

/* ── Instructions Overlay ── */
.gtmp-instructions { position: absolute; inset: 0; z-index: 999; background: rgba(27,42,74,0.85); display: flex; align-items: center; justify-content: center; backdrop-filter: blur(4px); }
.gtmp-instructions-content { background: var(--gtmp-card); border-radius: 14px; padding: 32px; max-width: 420px; text-align: left; box-shadow: 0 8px 40px rgba(0,0,0,0.3); }
.gtmp-instructions-content h3 { font-size: 20px; color: var(--gtmp-primary); margin: 0 0 16px; }
.gtmp-instructions-content ol { margin: 0; padding-left: 20px; font-size: 14px; line-height: 1.8; color: var(--gtmp-text2); }
.gtmp-instructions-content ol strong { color: var(--gtmp-primary); }
.gtmp-btn-dismiss { display: block; width: 100%; margin-top: 20px; padding: 12px; background: var(--gtmp-primary); color: #fff; border: none; border-radius: 8px; font-size: 14px; font-weight: 700; font-family: var(--gtmp-font); cursor: pointer; transition: background 0.2s; }
.gtmp-btn-dismiss:hover { background: #2A4166; }

/* ── Panel ── */
.gtmp-panel { background: var(--gtmp-card); border: 1px solid var(--gtmp-border); border-top: none; border-radius: 0 0 var(--gtmp-r) var(--gtmp-r); padding: 16px; }
.gtmp-panel-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; flex-wrap: wrap; gap: 8px; }
.gtmp-panel-header h3 { font-size: 16px; color: var(--gtmp-primary); margin: 0; }
.gtmp-panel-actions { display: flex; gap: 6px; }
.gtmp-action-btn { display: flex; align-items: center; gap: 4px; padding: 6px 12px; border: 1px solid var(--gtmp-border); border-radius: 6px; background: var(--gtmp-card); font-size: 11px; font-weight: 600; font-family: var(--gtmp-font); color: var(--gtmp-text2); cursor: pointer; transition: all 0.2s; }
.gtmp-action-btn:hover { border-color: var(--gtmp-primary); color: var(--gtmp-primary); }

/* ── Totals ── */
.gtmp-totals { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 14px; }
.gtmp-total-card { background: var(--gtmp-bg); border-radius: 8px; padding: 12px 14px; text-align: center; }
.gtmp-total-label { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: 0.8px; font-weight: 700; color: var(--gtmp-text3); margin-bottom: 2px; }
.gtmp-total-value { display: block; font-size: 20px; font-weight: 800; color: var(--gtmp-primary); }

/* ── Measurements List ── */
.gtmp-measurements-list { max-height: 300px; overflow-y: auto; }
.gtmp-empty-msg { text-align: center; color: var(--gtmp-text3); font-size: 13px; padding: 20px 0; }
.gtmp-meas-item { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border: 1px solid var(--gtmp-border); border-radius: 8px; margin-bottom: 8px; transition: background 0.2s; }
.gtmp-meas-item:hover { background: var(--gtmp-bg); }
.gtmp-meas-dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; }
.gtmp-meas-info { flex: 1; }
.gtmp-meas-label { font-size: 13px; font-weight: 700; color: var(--gtmp-text); }
.gtmp-meas-value { font-size: 18px; font-weight: 800; color: var(--gtmp-primary); }
.gtmp-meas-type { font-size: 11px; color: var(--gtmp-text3); }
.gtmp-meas-delete { background: none; border: none; cursor: pointer; color: var(--gtmp-text3); padding: 4px; transition: color 0.2s; }
.gtmp-meas-delete:hover { color: #C53030; }

/* ── Responsive ── */
@media (max-width: 640px) {
    .gtmp-toolbar { flex-direction: column; gap: 8px; }
    .gtmp-toolbar-left { width: 100%; }
    .gtmp-tool-group { width: 100%; justify-content: stretch; }
    .gtmp-tool-btn { flex: 1; justify-content: center; padding: 8px 8px; }
    .gtmp-tool-btn span { display: none; }
    .gtmp-totals { grid-template-columns: repeat(3, 1fr); gap: 6px; }
    .gtmp-total-value { font-size: 16px; }
    .gtmp-label-options { grid-template-columns: repeat(2, 1fr); }
    .gtmp-panel-actions { flex-wrap: wrap; }
    .gtmp-action-btn span { display: none; }
}
