:root{
  --bg:#0e1116; --bg2:#161b22; --card:#1c232d; --line:#2a323d;
  --txt:#e6edf3; --muted:#8b949e; --accent:#f0883e; --accent2:#3fb950;
  --danger:#f85149; --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--txt);min-height:100vh;-webkit-tap-highlight-color:transparent}
.hidden{display:none !important}
.muted{color:var(--muted)}
.center{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.center-text{text-align:center;margin-top:40px}
.error{color:var(--danger);font-size:.9rem;margin-top:8px}

/* CARDS / AUTH */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.auth-card{width:100%;max-width:360px;text-align:center}
.auth-card h1{font-size:1.6rem;margin-bottom:6px}
.auth-card input{margin:16px 0 12px}

input,select,textarea{width:100%;padding:12px 14px;background:var(--bg2);border:1px solid var(--line);border-radius:10px;color:var(--txt);font-size:1rem;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
textarea{resize:vertical;min-height:70px}

button{cursor:pointer;border:none;border-radius:10px;padding:12px 16px;font-size:1rem;font-weight:600;font-family:inherit;transition:.15s;display:inline-flex;align-items:center;justify-content:center;gap:7px}
.ico{flex:0 0 auto;vertical-align:middle}
.icon-only{gap:0;padding-left:10px;padding-right:10px}
h1 .ico,.brand .ico{vertical-align:-4px}
button.primary{background:var(--accent);color:#1a1a1a;width:100%}
button.primary:hover{filter:brightness(1.08)}
button.ghost{background:transparent;color:var(--muted);padding:8px 12px}
button.ghost:hover{color:var(--txt)}
button.small{padding:7px 12px;font-size:.85rem}
button.danger{background:var(--danger);color:#fff}
button.success{background:var(--accent2);color:#0b1a0e}
button.outline{background:transparent;border:1px solid var(--line);color:var(--txt)}

.members{display:flex;flex-direction:column;gap:12px;margin-top:18px}
.members button{background:var(--bg2);border:1px solid var(--line);color:var(--txt);padding:16px;font-size:1.1rem}
.members button:hover{border-color:var(--accent)}

/* TOPBAR */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:var(--bg2);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand{font-weight:700;font-size:1.15rem}
.topbar-right{display:flex;align-items:center;gap:10px}
.chip{background:var(--accent);color:#1a1a1a;padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:700}

.toolbar{display:flex;gap:10px;padding:16px 18px;max-width:900px;margin:0 auto;width:100%}
.toolbar input{flex:1}
.toolbar button{width:auto;white-space:nowrap}

/* REST LIST */
.rest-list{max-width:900px;margin:0 auto;padding:0 18px 60px;display:flex;flex-direction:column;gap:12px}
.rest-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.rest-header{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;cursor:pointer;gap:12px}
.rest-header:hover{background:#212a35}
.rest-title{font-size:1.15rem;font-weight:700}
.rest-sub{font-size:.85rem;color:var(--muted);margin-top:3px}
.rest-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.tag{background:var(--bg2);border:1px solid var(--line);padding:2px 9px;border-radius:20px;font-size:.75rem;color:var(--muted)}
.rest-body{padding:0 18px 18px;border-top:1px solid var(--line);display:none}
.rest-card.open .rest-body{display:block}
.rest-actions{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}

.section-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:18px 0 10px;font-weight:700}

/* PRODUCTOS */
.prod{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:8px}
.prod-top{display:flex;justify-content:space-between;gap:10px}
.prod-name{font-weight:600}
.prod-desc{font-size:.82rem;color:var(--muted);margin-top:2px}
.prod-price{color:var(--accent);font-weight:700;white-space:nowrap}
.prod-cat{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.ratings-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;align-items:center}
.rate-pill{display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:4px 10px;font-size:.8rem}
.rate-pill b{color:var(--accent2)}
.rate-input{width:62px;padding:6px 8px;font-size:.85rem}

/* VISITAS */
.visita{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:8px}
.visita-head{display:flex;justify-content:space-between;font-size:.9rem}
.visita-total{color:var(--accent);font-weight:700}
.ticket-thumb{max-width:80px;border-radius:8px;margin-top:8px;cursor:pointer}
.linea{display:flex;justify-content:space-between;font-size:.82rem;color:var(--muted);padding:2px 0}

/* MODAL */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);display:flex;align-items:flex-start;justify-content:center;padding:20px;z-index:50;overflow-y:auto}
.modal{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);width:100%;max-width:560px;margin:auto}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:18px;border-bottom:1px solid var(--line)}
.modal-body{padding:18px;display:flex;flex-direction:column;gap:12px}
.modal-body label{font-size:.85rem;color:var(--muted);margin-bottom:-6px}
.row{display:flex;gap:10px}
.row>*{flex:1}

/* TOAST + LOADER */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--line);padding:12px 20px;border-radius:30px;z-index:100;font-size:.9rem}
.toast.err{border-color:var(--danger);color:var(--danger)}
.loader-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:200}
.spinner{width:48px;height:48px;border:4px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.dropzone{border:2px dashed var(--line);border-radius:12px;padding:24px;text-align:center;color:var(--muted);cursor:pointer}
.dropzone:hover{border-color:var(--accent)}

/* Buscador de Google (PlaceAutocompleteElement) */
.pac-host{width:100%}
.pac-host gmp-place-autocomplete{width:100%}
.gm-style .pac-target-input,gmp-place-autocomplete{width:100%}
