/* components.css — Botones, pills, cards, modals, form, chat */

/* ── BOTONES ── */
.btn{border:none;border-radius:10px;padding:10px 16px;font-family:var(--fb);font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:opacity .1s}
.btn:active{opacity:.8}
.btn svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-primary{background:var(--gold);color:var(--night)}
.btn-ghost{background:var(--card);color:var(--text2);border:1px solid var(--border)}
.btn-green{background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.3)}
.btn-red{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.25)}
.btn-blue{background:var(--blue);color:var(--night)}
.btn-full{width:100%;justify-content:center;padding:14px;font-size:15px;border-radius:var(--r)}

/* ── PILLS ── */
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid}
.pill-pending{background:rgba(245,158,11,.1);color:#f59e0b;border-color:rgba(245,158,11,.3)}
.pill-confirmed{background:rgba(96,165,250,.1);color:#60a5fa;border-color:rgba(96,165,250,.3)}
.pill-enroute{background:rgba(245,200,66,.1);color:var(--gold);border-color:rgba(245,200,66,.3)}
.pill-delivered{background:rgba(34,197,94,.1);color:var(--green);border-color:rgba(34,197,94,.3)}
.pill-dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* ── FORM ── */
.form-wrap{padding:16px 20px;display:flex;flex-direction:column;gap:16px}
.fg{display:flex;flex-direction:column;gap:6px}
.fl{font-size:12px;font-weight:700;color:var(--text3);font-family:var(--fh);text-transform:uppercase;letter-spacing:.5px}
.fi{background:var(--card2);border:1.5px solid var(--border);border-radius:var(--rs);padding:13px 14px;font-family:var(--fb);font-size:15px;color:var(--text);outline:none;transition:border-color .15s;width:100%}
.fi:focus{border-color:var(--gold)}
.fi::placeholder{color:var(--text3)}

/* ── SEC HEADER ── */
.sec-hdr{padding:20px 20px 12px;display:flex;align-items:center;justify-content:space-between}
.sec-title{font-family:var(--fh);font-size:22px;font-weight:800;letter-spacing:-.5px}

/* ── TABS ── */
.tabs{display:flex;background:var(--card2);border-radius:12px;padding:3px;margin:12px 20px 0}
.tab-btn{flex:1;padding:9px;border:none;background:transparent;font-family:var(--fh);font-size:12px;font-weight:700;color:var(--text3);border-radius:9px;cursor:pointer;transition:all .15s;letter-spacing:.5px;text-transform:uppercase}
.tab-btn.on{background:var(--gold);color:var(--night)}

/* ── SEARCH ── */
.search-wrap{padding:12px 20px 0}
.search-inp{width:100%;background:var(--card2);border:1.5px solid var(--border);border-radius:10px;padding:12px 14px 12px 40px;font-family:var(--fb);font-size:14px;color:var(--text);outline:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='M21 21l-4.35-4.35'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:13px center}
.search-inp:focus{border-color:var(--gold)}

/* ── INFO ROW ── */
.info-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2)}
.info-row svg{width:13px;height:13px;stroke:var(--text3);stroke-width:2;fill:none;flex-shrink:0}

/* ── MODALS ── */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(4px)}
.modal-ov.on{opacity:1;pointer-events:all}
.modal-sh{background:var(--card);border-radius:24px 24px 0 0;width:100%;max-width:430px;padding:0 0 env(safe-area-inset-bottom);transform:translateY(40px);transition:transform .3s cubic-bezier(.32,.72,0,1);max-height:90vh;overflow-y:auto;border-top:1px solid var(--border2)}
.modal-ov.on .modal-sh{transform:translateY(0)}
.mhandle{width:40px;height:4px;background:var(--border2);border-radius:2px;margin:14px auto 8px}
.mtitle{font-family:var(--fh);font-size:20px;font-weight:800;padding:0 20px 14px;letter-spacing:-.4px}

/* ── HISTORY ── */
.hist-item{margin:0 20px 8px;background:var(--card);border-radius:var(--rs);border:1px solid var(--border);padding:12px 14px;display:flex;align-items:center;gap:12px}
.hist-date{font-size:11px;color:var(--text3);min-width:56px;line-height:1.4}
.hist-main{font-size:13px;font-weight:700;color:var(--text);font-family:var(--fm)}
.hist-label{font-size:11px;color:var(--text2);margin-top:1px}
.hist-price{margin-left:auto;font-size:13px;font-weight:700;color:var(--gold);font-family:var(--fm)}

/* ── ORDER CARD ── */
.order-card{background:var(--card2);border-radius:var(--r);border:1px solid var(--border);margin:0 20px 10px;overflow:hidden}
.oc-top{padding:14px 16px 10px;display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.oc-client{font-size:15px;font-weight:600;font-family:var(--fh)}
.oc-time{font-size:11px;color:var(--text3);margin-top:2px}
.oc-mid{padding:0 16px 12px;display:flex;flex-direction:column;gap:8px}
.oc-route{display:flex;align-items:flex-start;gap:10px}
.rd{display:flex;flex-direction:column;align-items:center;gap:3px;padding-top:3px}
.rd-from{width:9px;height:9px;border-radius:50%;background:var(--gold);flex-shrink:0}
.rd-line{width:2px;height:18px;background:var(--border2)}
.rd-to{width:9px;height:9px;border-radius:50%;border:2px solid var(--green);flex-shrink:0}
.rt{display:flex;flex-direction:column;gap:8px}
.rt-from{font-size:13px;font-weight:600}
.rt-to{font-size:13px;color:var(--text2)}
.oc-bot{padding:10px 16px;border-top:1px solid var(--border);display:flex;gap:8px}

/* ── CHAT ── */
.chat-fab{position:fixed;bottom:88px;right:16px;width:52px;height:52px;background:var(--gold);border:none;border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:30;box-shadow:0 4px 20px rgba(245,200,66,.4)}
.chat-fab.on{display:flex}
.chat-fab svg{width:24px;height:24px;stroke:var(--night);stroke-width:2;fill:none}
.chat-fab-dot{position:absolute;top:4px;right:4px;width:10px;height:10px;background:var(--red);border-radius:50%;border:2px solid var(--gold);display:none}
.chat-ov{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:50;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(4px)}
.chat-ov.on{opacity:1;pointer-events:all}
.chat-sh{background:var(--card);border-radius:24px 24px 0 0;width:100%;max-width:430px;height:70vh;display:flex;flex-direction:column;transform:translateY(40px);transition:transform .3s cubic-bezier(.32,.72,0,1);border-top:1px solid var(--border2)}
.chat-ov.on .chat-sh{transform:translateY(0)}
.chat-hdr{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0}
.chat-hdr-av{width:36px;height:36px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;color:var(--night);font-family:var(--fh)}
.chat-hdr-name{font-weight:700;font-size:14px;font-family:var(--fh)}
.chat-hdr-status{font-size:11px;color:var(--green)}
.chat-close{margin-left:auto;width:30px;height:30px;background:var(--card2);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--border)}
.chat-close svg{width:14px;height:14px;stroke:var(--text2);stroke-width:2;fill:none}
.chat-msgs{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:8px}
.chat-msgs::-webkit-scrollbar{display:none}
.chat-msg{display:flex;flex-direction:column;max-width:80%}
.chat-msg.me{align-self:flex-end;align-items:flex-end}
.chat-msg.them{align-self:flex-start}
.chat-bub{padding:9px 13px;border-radius:16px;font-size:14px;line-height:1.4}
.chat-msg.me .chat-bub{background:var(--gold);color:var(--night);border-bottom-right-radius:4px}
.chat-msg.them .chat-bub{background:var(--card2);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}
.chat-time{font-size:10px;color:var(--text3);margin-top:3px;font-family:var(--fm)}
.chat-inp-row{padding:10px 14px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--border);display:flex;align-items:flex-end;gap:8px;flex-shrink:0}
.chat-inp{flex:1;background:var(--card2);border:1.5px solid var(--border);border-radius:12px;padding:10px 14px;font-family:var(--fb);font-size:14px;color:var(--text);outline:none;resize:none;max-height:100px;line-height:1.4}
.chat-inp:focus{border-color:var(--gold)}
.chat-inp::placeholder{color:var(--text3)}
.chat-send{width:40px;height:40px;background:var(--gold);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-send svg{width:17px;height:17px;stroke:var(--night);stroke-width:2.2;fill:none}

/* ── AUTOCOMPLETE ── */
.ac-wrap{position:relative;width:100%}
.ac-input-row{display:flex;align-items:center}
.ac-inp{flex:1;background:var(--card2);border:1.5px solid var(--border);border-radius:var(--rs) 0 0 var(--rs);padding:13px 14px;font-family:var(--fb);font-size:15px;color:var(--text);outline:none;transition:border-color .15s;width:100%}
.ac-inp:focus{border-color:var(--gold)}
.ac-inp::placeholder{color:var(--text3)}
.ac-inp.solo{border-radius:var(--rs)}
.ac-gps-btn{width:46px;height:46px;flex-shrink:0;background:var(--card2);border:1.5px solid var(--border);border-left:none;border-radius:0 var(--rs) var(--rs) 0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.ac-gps-btn:hover{background:rgba(245,200,66,.1);border-color:var(--gold)}
.ac-gps-btn svg{width:18px;height:18px;stroke:var(--gold);stroke-width:2;fill:none}
.ac-gps-btn.loading svg{animation:sp .7s linear infinite}
.ac-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--card);border:1px solid var(--border2);border-radius:var(--rs);overflow:hidden;z-index:200;box-shadow:0 8px 24px rgba(0,0,0,.5);display:none}
.ac-dropdown.open{display:block}
.ac-item{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}
.ac-item:last-child{border-bottom:none}
.ac-item:hover{background:var(--card2)}
.ac-item-icon{width:30px;height:30px;border-radius:8px;background:rgba(245,200,66,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.ac-item-icon svg{width:14px;height:14px;stroke:var(--gold);stroke-width:2;fill:none}
.ac-item-main{font-size:14px;font-weight:600;color:var(--text);line-height:1.3}
.ac-item-sub{font-size:11px;color:var(--text3);margin-top:2px}
.ac-loading{padding:14px;text-align:center;font-size:13px;color:var(--text3);display:flex;align-items:center;justify-content:center;gap:8px}
.ac-loading .spin{border-top-color:var(--gold)}
.ac-map-preview{margin-top:8px;border-radius:var(--rs);overflow:hidden;border:1px solid var(--border);display:none}
.ac-map-preview.on{display:block}
#dest-map{height:140px;width:100%}
