/* ===== VARIÁVEIS ===== */
:root {
  --bg-dark: #1a0802; --bg-med: #2a1005; --bg-card: #3d1f0a;
  --gold: #f0c050; --gold-light: #f5d78e; --amber: #e8a020;
  --text-main: #f5deb3; --text-muted: #c8a87a; --border: #6b3d1a; --radius: 14px;
}
* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html, body { min-height:100%; background:var(--bg-dark); color:var(--text-main); font-family:'Crimson Pro',serif; }

/* ===== HEADER ===== */
.header {
  display:flex; align-items:stretch; min-height:90px;
  border-bottom:2px solid rgba(240,192,80,0.3);
  box-shadow:0 3px 20px rgba(0,0,0,0.6); overflow:hidden;
}
.header-logo-wrap {
  width:100px; min-width:100px; flex-shrink:0; background:#1a0802;
  display:flex; align-items:center; justify-content:center;
  border-right:1px solid rgba(240,192,80,0.2);
}
.header-logo-img { width:90px; height:90px; object-fit:cover; }
.header-logo-placeholder { font-size:36px; opacity:0.5; display:flex; align-items:center; justify-content:center; }
.header-info-wrap {
  flex:1; position:relative; overflow:hidden;
  background:linear-gradient(135deg,#1a0802,#2a1005);
  display:flex; align-items:flex-end; flex-direction:column;
  justify-content:center; padding:12px 16px;
}
.header-bg-logo {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0.18; filter:grayscale(0.3); pointer-events:none;
}
.header-store-name {
  position:relative; z-index:1;
  font-family:'Cinzel',serif; font-size:14px; font-weight:900;
  color:var(--gold); text-shadow:0 2px 8px rgba(0,0,0,0.8), 0 0 20px rgba(240,192,80,0.3);
  line-height:1.2; letter-spacing:0.5px; text-align:right;
}
.header-powered {
  position:relative; z-index:1;
  font-size:10px; color:var(--text-muted); text-align:right; margin-top:2px;
}

/* ===== TÍTULOS ===== */
.agende-titulo {
  font-family:'Cinzel',serif; font-size:16px; font-weight:700;
  color:var(--gold); text-align:center; padding:18px 16px 4px; letter-spacing:0.5px;
}
.taxi-intro {
  font-size:13px; color:var(--text-muted); text-align:center;
  padding:0 20px 4px; line-height:1.5;
}

/* ===== FORM WRAP ===== */
.taxi-form-wrap {
  padding:12px 16px 110px;
  display:flex; flex-direction:column; gap:12px;
}

/* ===== LOCATION CARDS ===== */
.location-card {
  background:linear-gradient(135deg, var(--bg-card), var(--bg-med));
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  display:flex; flex-direction:column; gap:9px;
}
.location-card-header {
  display:flex; align-items:center; gap:8px;
  margin-bottom:2px;
}
.location-card-title {
  font-family:'Cinzel',serif; font-size:13px; color:var(--gold); font-weight:700;
}
.optional-label { font-size:11px; color:var(--text-muted); font-weight:400; }
.location-dot  { font-size:20px; line-height:1; }
.origin-dot    { color:#4cbe60; }
.dest-dot      { color:#e07070; }

/* ===== INPUTS ===== */
.form-input {
  width:100%;
  background:var(--bg-dark);
  border:1px solid var(--border);
  border-radius:10px;
  padding:11px 14px;
  color:var(--text-main);
  font-size:14px;
  font-family:'Crimson Pro',serif;
  outline:none;
  transition:border-color 0.2s;
}
.form-input::placeholder { color:rgba(200,168,122,0.4); }
.form-input:focus { border-color:rgba(240,192,80,0.5); }
.form-textarea { resize:none; height:64px; }

/* ===== NÚMERO + SEM NÚMERO ===== */
.numero-row {
  display:flex; align-items:center; gap:10px;
}
.numero-input { flex:1; min-width:0; }
.sem-numero-label {
  display:flex; align-items:center; gap:6px;
  white-space:nowrap;
  font-size:12px; color:var(--text-muted); cursor:pointer;
  flex-shrink:0;
}
.sem-numero-label input[type=checkbox] {
  width:16px; height:16px;
  accent-color:var(--gold);
  cursor:pointer;
  flex-shrink:0;
}

/* ===== MAP BUTTON ===== */
.map-btn {
  background:rgba(240,192,80,0.08);
  border:1.5px solid rgba(240,192,80,0.3);
  color:var(--gold);
  font-family:'Cinzel',serif; font-size:12px;
  padding:10px 14px; border-radius:50px;
  cursor:pointer; text-align:center;
  transition:all 0.2s; display:flex; align-items:center; justify-content:center; gap:4px;
}
.map-btn:active { background:rgba(240,192,80,0.18); }
.map-btn-required {
  border-color:rgba(76,190,96,0.5);
  color:#4cbe60;
  background:rgba(76,190,96,0.07);
}
.map-btn-confirmed {
  background:rgba(76,190,96,0.15) !important;
  border-color:rgba(76,190,96,0.6) !important;
  color:#4cbe60 !important;
}
.map-required-badge {
  background:rgba(76,190,96,0.2);
  color:#4cbe60;
  border-radius:50px;
  font-size:10px;
  padding:1px 8px;
  border:1px solid rgba(76,190,96,0.3);
}

/* ===== MAP PREVIEW ===== */
.map-preview { border-radius:10px; overflow:hidden; border:1px solid var(--border); }
.map-preview.hidden { display:none; }
.mini-map { height:110px; }
.map-label {
  font-size:11px; color:var(--text-muted); padding:6px 10px;
  background:var(--bg-med); border-top:1px solid var(--border);
  line-height:1.4;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}

/* ===== WHATSAPP BUTTON ===== */
.whatsapp-btn {
  width:100%; padding:16px;
  background:linear-gradient(135deg,#25d366,#128c7e);
  border:none; border-radius:50px;
  color:#fff; font-family:'Cinzel',serif; font-size:15px; font-weight:700;
  cursor:pointer; box-shadow:0 4px 20px rgba(37,211,102,0.3);
  transition:transform 0.15s;
}
.whatsapp-btn:active { transform:scale(0.98); }

/* ===== CONTACT BUTTONS ===== */
.contact-buttons-wrap {
  display:flex; gap:8px; padding:12px 16px 4px; flex-wrap:wrap;
}
.contact-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 14px; border-radius:50px;
  font-family:'Cinzel',serif; font-size:11px;
  text-decoration:none; font-weight:600;
}
.contact-btn-whatsapp { background:rgba(37,211,102,0.15); color:#25d366; border:1px solid rgba(37,211,102,0.3); }
.contact-btn-instagram { background:rgba(225,72,154,0.15); color:#e1489a; border:1px solid rgba(225,72,154,0.3); }
.contact-btn-maps      { background:rgba(66,133,244,0.15); color:#4285f4; border:1px solid rgba(66,133,244,0.3); }

/* ===== MAP MODAL ===== */
.map-modal {
  position:fixed; inset:0; z-index:400;
  background:var(--bg-dark);
  display:flex; flex-direction:column;
}
.map-modal.hidden { display:none; }
.map-modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 16px; flex-shrink:0;
  background:linear-gradient(135deg,#2a1005,#3d1f0a);
  border-bottom:1px solid var(--border);
  font-family:'Cinzel',serif; font-size:13px; color:var(--gold); font-weight:700;
}
.map-back-btn {
  background:none; border:none; color:var(--gold);
  font-family:'Cinzel',serif; font-size:13px; cursor:pointer; padding:4px 8px;
}
.map-search-bar {
  position:relative; padding:8px 12px;
  background:var(--bg-med); flex-shrink:0; z-index:10;
}
.map-search-input {
  width:100%; background:var(--bg-card);
  border:1px solid var(--border); border-radius:50px;
  padding:10px 16px; color:var(--text-main);
  font-size:14px; font-family:'Crimson Pro',serif; outline:none;
}
.map-search-input::placeholder { color:rgba(200,168,122,0.4); }
#map-container { flex:1; min-height:0; }
.map-modal-footer {
  padding:12px 16px; flex-shrink:0;
  background:linear-gradient(to top,var(--bg-dark),var(--bg-med));
  border-top:1px solid var(--border);
}
.map-selected-text {
  font-size:12px; color:var(--text-muted);
  margin-bottom:8px; line-height:1.4;
  display:-webkit-box; -webkit-line-clamp:2;
  -webkit-box-orient:vertical; overflow:hidden;
}
.map-confirm-btn {
  width:100%; padding:13px;
  background:linear-gradient(135deg,#25d366,#128c7e);
  border:none; border-radius:50px;
  color:#fff; font-family:'Cinzel',serif; font-size:14px; font-weight:700; cursor:pointer;
}
.map-confirm-btn.hidden { display:none; }

/* Suggestions dentro do modal */
.map-search-bar .address-suggestions {
  position:absolute; top:calc(100% - 8px); left:12px; right:12px; width:auto;
}

/* ===== SUGGESTIONS ===== */
.address-suggestions {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:10px;
  z-index:200;
  max-height:200px; overflow-y:auto;
  box-shadow:0 8px 28px rgba(0,0,0,0.7);
}
.address-suggestions.hidden { display:none; }
.suggestion-item {
  padding:10px 14px;
  font-size:13px; color:var(--text-main);
  cursor:pointer;
  border-bottom:1px solid rgba(107,61,26,0.3);
  line-height:1.4;
  transition:background 0.15s;
}
.suggestion-item:last-child { border-bottom:none; }
.suggestion-item:active { background:rgba(240,192,80,0.1); }

/* ===== SHAKE ANIMATION ===== */
@keyframes shake {
  0%,100%{ transform:translateX(0); }
  20%    { transform:translateX(-6px); }
  40%    { transform:translateX(6px); }
  60%    { transform:translateX(-4px); }
  80%    { transform:translateX(4px); }
}
.shake { animation:shake 0.5s ease; border-color:rgba(224,112,112,0.7) !important; }

/* ===== ADMIN ===== */
.admin-panel {
  position:fixed; inset:0;
  background:linear-gradient(160deg,#1a0800,#120500);
  z-index:300; overflow-y:auto; display:flex; flex-direction:column;
}
.admin-panel.hidden { display:none; }
.admin-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px;
  background:linear-gradient(135deg,#2a1005,#3d1f0a);
  border-bottom:1px solid var(--border);
  font-family:'Cinzel',serif; font-size:14px; color:var(--gold); font-weight:700;
  position:sticky; top:0; z-index:10;
}
.admin-close-btn {
  background:rgba(240,192,80,0.15); border:1px solid var(--gold);
  color:var(--gold); padding:6px 14px; border-radius:50px;
  font-family:'Cinzel',serif; font-size:12px; cursor:pointer;
}
.admin-tabs {
  display:flex; border-bottom:1px solid var(--border);
  background:var(--bg-med); position:sticky; top:49px; z-index:9;
}
.admin-tab {
  flex:1; padding:12px 2px; text-align:center;
  font-family:'Cinzel',serif; font-size:10px; color:var(--text-muted);
  cursor:pointer; border-bottom:2px solid transparent;
  text-transform:uppercase; letter-spacing:0.3px;
}
.admin-tab.active { color:var(--gold); border-bottom-color:var(--gold); }
.tab-content { display:none; padding:16px; }
.tab-content.active { display:block; }
.admin-form { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.admin-form label {
  font-family:'Cinzel',serif; font-size:11px;
  color:var(--gold); text-transform:uppercase; letter-spacing:0.3px;
}
.admin-input {
  width:100%; background:var(--bg-card); border:1px solid var(--border);
  border-radius:10px; padding:10px 14px; color:var(--text-main);
  font-size:14px; font-family:'Crimson Pro',serif; outline:none;
}
.admin-input::placeholder { color:rgba(200,168,122,0.4); }
.admin-file-input { color:var(--text-muted); font-size:13px; }
.admin-btn {
  width:100%; padding:13px;
  background:linear-gradient(135deg,var(--gold),var(--amber));
  border:none; border-radius:50px;
  color:#1a0802; font-family:'Cinzel',serif; font-size:13px; font-weight:700; cursor:pointer;
}
.admin-btn.secondary {
  background:rgba(240,192,80,0.15); color:var(--gold); border:1px solid var(--gold);
}

/* ===== STATS ===== */
.stats-periods { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:14px; }
.stats-period-btn {
  padding:6px 12px; border-radius:50px;
  background:rgba(240,192,80,0.08); border:1px solid var(--border);
  color:var(--text-muted); font-family:'Cinzel',serif; font-size:11px; cursor:pointer;
}
.stats-period-btn.active { background:rgba(240,192,80,0.2); border-color:var(--gold); color:var(--gold); }
.stats-count-wrap {
  text-align:center; padding:22px 16px;
  background:rgba(240,192,80,0.05); border:1px solid rgba(240,192,80,0.15); border-radius:14px;
  margin-bottom:4px;
}
.stats-count-number { font-family:'Cinzel',serif; font-size:56px; font-weight:900; color:var(--gold); line-height:1; }
.stats-count-label  { font-size:12px; color:var(--text-muted); margin-top:6px; }
.stats-item {
  background:var(--bg-med); border:1px solid var(--border); border-radius:10px;
  padding:11px 13px; margin-bottom:8px; font-size:12px; color:var(--text-muted); line-height:1.8;
}
.stats-item strong { color:var(--gold-light); font-size:13px; }

/* ===== MISC ===== */
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }
.hidden { display:none !important; }

/* Leaflet overrides */
.leaflet-control-attribution { font-size:9px !important; }
.leaflet-control-zoom { border:1px solid var(--border) !important; }
.leaflet-control-zoom a { background:var(--bg-card) !important; color:var(--gold) !important; border-color:var(--border) !important; }
