@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap');

:root{
  --bg:#0e0e11;
  --panel:#15151b;
  --muted:#8b8ca3;
  --text:#f2f2f7;
  --accent:#e9465a;
  --accent-2:#7f5af0;
  --border:#242436;
  --chip:#1c1c26;
  --chip-hover:#232336;
  --focus:#2a2a44;
  --shadow:0 10px 25px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:radial-gradient(1200px 600px at 20% -10%, rgba(127,90,240,.11), transparent 60%),
             radial-gradient(900px 500px at 110% 10%, rgba(233,70,90,.10), transparent 60%),
             var(--bg);
  color:var(--text);
  display:flex;flex-direction:column;
}

.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;border-bottom:1px solid var(--border);backdrop-filter:saturate(120%) blur(6px);
  position:sticky;top:0;z-index:20;background:rgba(14,14,17,.6)
}
.topbar h1{margin:0;font-size:1.25rem;font-weight:700;letter-spacing:.2px;display:flex;gap:10px;align-items:center}
.topbar h1 i{color:var(--accent)}
.wallet-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(180deg, #1b1b25, #13131a);
  border:1px solid var(--border);padding:8px 12px;border-radius:999px;
  box-shadow:var(--shadow);font-weight:600
}
.wallet-pill i{color:var(--accent-2)}

.shell{display:flex;gap:16px;padding:16px;height:calc(100vh - 66px)}
.left{flex:1;min-width:0;display:flex;flex-direction:column;gap:12px}
.right{width:320px;min-width:280px;display:flex;flex-direction:column;gap:12px}

.map-controls .search{display:flex;gap:8px}
.map-controls input{
  flex:1;background:var(--panel);border:1px solid var(--border);color:var(--text);
  padding:12px 14px;border-radius:10px;outline:none
}
.map-controls input:focus{border-color:#3b3b5e;box-shadow:0 0 0 3px rgba(127,90,240,.18)}
.btn{
  background:var(--chip);border:1px solid var(--border);color:var(--text);
  padding:12px 14px;border-radius:10px;cursor:pointer;transition:.2s;display:inline-flex;align-items:center;justify-content:center;min-width:48px
}
.btn:hover{background:var(--chip-hover);transform:translateY(-1px)}
.btn-full{
  background:linear-gradient(180deg, var(--accent-2), #6a49f1);
  border:1px solid #5a3ee8;color:#fff;padding:12px 14px;border-radius:12px;width:100%;
  cursor:pointer;font-weight:700;letter-spacing:.2px;box-shadow:0 8px 20px rgba(127,90,240,.25);transition:.2s
}
.btn-full:hover{transform:translateY(-1px)}

.map-wrap{
  position:relative;flex:1;border-radius:14px;overflow:hidden;border:1px solid var(--border);
  box-shadow:var(--shadow);background:var(--panel)
}
#map{width:100%;height:100%}
#zoom-message{
  position:absolute;inset:auto 50% 50% auto;transform:translate(50%,50%);
  display:flex;gap:10px;align-items:center;white-space:nowrap;
  background:rgba(21,21,27,.86);padding:10px 16px;border-radius:999px;border:1px solid var(--border)
}

.panel{
  background:linear-gradient(180deg, #161620, #13131a);
  border:1px solid var(--border);border-radius:16px;padding:14px;
  box-shadow:var(--shadow)
}
.panel h3{margin:0 0 10px;font-size:.95rem;font-weight:700;color:#fff}

.palette{
  display:grid;grid-template-columns:repeat(6, 1fr);gap:10px
}
.color-box{
  height:36px;border-radius:12px;border:2px solid transparent;cursor:pointer;transition:.15s;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06), 0 2px 8px rgba(0,0,0,.25)
}
.color-box:hover{transform:translateY(-1px)}
.color-box.selected{border-color:var(--accent-2);box-shadow:0 0 0 3px rgba(127,90,240,.25)}

.tools-row{display:flex;gap:10px;margin-top:12px}
.tool-btn{
  flex:1;background:linear-gradient(180deg, #262638, #1c1c2a);
  border:1px solid var(--border);color:#fff;padding:12px;border-radius:12px;cursor:pointer;font-weight:700;transition:.2s
}
.tool-btn:hover{background:#26263a}

.custom-color{display:grid;grid-template-columns:90px 1fr;gap:10px;align-items:center}
.custom-color input[type="color"]{
  width:100%;height:42px;border-radius:12px;border:1px solid var(--border);background:var(--chip);padding:0
}
.custom-color input[type="text"]{
  background:var(--panel);border:1px solid var(--border);color:var(--text);
  padding:12px 14px;border-radius:12px;outline:none
}
.custom-color input[type="text"]:focus{border-color:#3b3b5e;box-shadow:0 0 0 3px rgba(127,90,240,.18);}

.message{
  margin:0;background:rgba(127,90,240,.08);border:1px solid #2c2552;color:#d9d6ff;
  padding:12px 14px;border-radius:12px;min-height:44px;display:flex;align-items:center
}

.leaflet-container{background:#0e0e11}
.leaflet-control-attribution{
  background:rgba(21,21,27,.7)!important;color:var(--muted)!important;border-top:1px solid var(--border)!important;padding:2px 8px!important
}
.leaflet-control-attribution a{color:#cfcfff!important}

@media (max-width: 980px){
  .shell{flex-direction:column}
  .right{width:auto}
}
