:root{--ink: #15211e;--pine: #0f5d52;--pine-700: #0b463e;--amber: #c9781a;--paper: #f6f7f4;--card: #ffffff;--line: #dde3de;--mute: #5c6b64;--ok: #1c7c54;--danger: #a32626;--display: "Space Grotesk", system-ui, sans-serif;--body: "Inter", system-ui, sans-serif;--safe-b: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);font-size:16px;line-height:1.5;-webkit-tap-highlight-color:transparent}h1,h2,h3{font-family:var(--display);margin:0;letter-spacing:-.01em}button{font-family:var(--body);font-weight:600;font-size:16px;cursor:pointer;border:1px solid transparent;border-radius:12px;padding:14px 18px;width:100%;transition:filter .15s}button:active{filter:brightness(.93)}button:focus-visible,a:focus-visible,input:focus-visible{outline:2px solid var(--pine);outline-offset:2px}.btn-primary{background:var(--pine);color:#fff}.btn-amber{background:var(--amber);color:#fff}.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}button:disabled{opacity:.5}input,textarea,select{font-family:var(--body);font-size:16px;width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink)}label{display:block;font-size:14px;font-weight:600;color:var(--mute);margin-bottom:6px}.field{margin-bottom:14px}.app{max-width:560px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--paper)}.topbar{position:sticky;top:0;z-index:5;background:var(--pine);color:#fff;padding:16px 18px;display:flex;align-items:center;justify-content:space-between}.topbar .brand{font-family:var(--display);font-weight:700;font-size:18px}.topbar .brand span{color:#f0c890}.topbar .quien{font-size:13px;opacity:.85}.scroll{flex:1;padding:16px 16px calc(86px + var(--safe-b))}.bottomnav{position:fixed;bottom:0;left:0;right:0;max-width:560px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;background:#fff;border-top:1px solid var(--line);padding-bottom:var(--safe-b)}.bottomnav a{text-align:center;padding:12px 4px 14px;text-decoration:none;color:var(--mute);font-size:12px;font-weight:600}.bottomnav a .ic{display:block;font-size:22px;line-height:1;margin-bottom:3px}.bottomnav a.active{color:var(--pine)}.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:12px;box-shadow:0 1px 2px #15211e0d}.card h3{font-size:17px;margin-bottom:4px}.card .meta{font-size:13px;color:var(--mute)}.pill{display:inline-block;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px;background:#eef6f3;color:var(--pine)}.pill.amber{background:#f6ecdb;color:var(--amber)}.tag-row{display:flex;gap:8px;align-items:center;margin-top:10px;flex-wrap:wrap}.points{font-family:var(--display);font-weight:700;color:var(--amber)}.section-title{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--mute);margin:6px 2px 12px}.empty{text-align:center;color:var(--mute);padding:48px 16px}.muted{color:var(--mute);font-size:14px}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#15211e73;z-index:20;display:flex;align-items:flex-end}.sheet{background:#fff;width:100%;max-width:560px;margin:0 auto;border-radius:20px 20px 0 0;padding:20px 18px calc(24px + var(--safe-b));max-height:92vh;overflow-y:auto}.sheet h2{font-size:19px;margin-bottom:4px}.sheet .sub{color:var(--mute);font-size:14px;margin-bottom:16px}.preview{width:100%;border-radius:12px;margin-bottom:12px;max-height:260px;object-fit:cover}.gps-box{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;margin-bottom:14px;font-size:14px}.gps-box.ok{border-color:#c4ddd6;background:#eef6f3;color:var(--pine-700)}.gps-box.err{border-color:#e6c4c4;background:#fbf0f0;color:var(--danger)}.alert{padding:13px 15px;border-radius:12px;font-size:14px;margin-bottom:14px}.alert.error{background:#fbf0f0;color:var(--danger);border:1px solid #e6c4c4}.alert.ok{background:#eef6f3;color:var(--pine-700);border:1px solid #c4ddd6}.tramo{display:flex;gap:8px;margin-bottom:8px}.tramo input.calle{flex:2}.tramo input.cant{flex:1}.tramo button{width:auto;padding:13px;background:#fff;border:1px solid var(--line);color:var(--danger)}.linkbtn{background:none;border:none;color:var(--pine);width:auto;padding:6px 0;font-weight:600}.login{display:flex;flex-direction:column;justify-content:center;min-height:100%;padding:28px 22px}.login .brand{font-family:var(--display);font-weight:700;font-size:30px;margin-bottom:4px}.login .brand span{color:var(--amber)}.login .sub{color:var(--mute);margin-bottom:28px}@media (prefers-reduced-motion: reduce){*{transition:none!important}}
