/* ArtI · The Thaislator — 3 columnas */
@import url('/assets/fonts/fonts.css');
:root {
  --bg-deep: #053330;
  --bg-card: rgba(10,40,38,0.55);
  --bd: rgba(201,168,94,0.22);
  --bd-soft: rgba(201,168,94,0.15);
  --ivory: #F3F0E7;
  --ivory-mute: rgba(243,240,231,0.65);
  --ivory-low: rgba(243,240,231,0.45);
  --gold: #C9A85E;
  --turquoise: #6FC6D3;
  --serif: 'Chonburi', Georgia, serif;
  --ui: 'Mitr', system-ui, sans-serif;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
a, button { color: inherit; text-decoration: none; font-family: inherit; }
button { background: none; border: none; cursor: pointer; }
img { display: block; max-width: 100%; }
html, body { font-family: var(--ui); background: var(--bg-deep); color: var(--ivory); height: 100vh; height: 100dvh; overflow: hidden; -webkit-font-smoothing: antialiased; }
.app { height: 100dvh; display: flex; flex-direction: column; overflow-y: auto; }
.img-col { position: relative; overflow: hidden; }
.hero-img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.ctrl-col { display: flex; flex-direction: column; gap: 12px; padding: 16px; }
.topbar { display: flex; justify-content: space-between; align-items: flex-start; }
.brand .logo { font-family: var(--serif); font-size: 30px; line-height: 1; letter-spacing: -0.5px; }
.brand .logo .i { color: var(--gold); }
.brand .tagline { font-size: 11px; letter-spacing: 2.5px; color: var(--ivory-low); margin-top: 5px; }
.lang-pills { display: flex; gap: 6px; }
.pill { border: 1px solid rgba(243,240,231,0.18); color: var(--ivory-mute); padding: 6px 12px; border-radius: 100px; font-size: 11px; transition: all .2s; }
.pill:hover { border-color: var(--bd); color: var(--gold); }
.pill.is-active { background: var(--turquoise); color: var(--bg-deep); border-color: var(--turquoise); font-weight: 500; }
.hero-thai { font-family: var(--serif); font-style: italic; font-size: 19px; color: var(--gold); margin-bottom: 5px; }
.hero-title { font-family: var(--serif); font-size: 32px; font-weight: 400; line-height: 1.1; letter-spacing: -0.5px; }
.hero-sub { font-size: 13px; color: var(--ivory-mute); margin-top: 8px; line-height: 1.4; }
.voice-bar { background: var(--bg-card); border: 1px solid var(--bd); border-radius: 100px; padding: 7px; display: flex; align-items: center; gap: 11px; width: 100%; transition: all .2s; }
.voice-bar:hover { border-color: var(--gold); background: rgba(10,40,38,0.7); }
.voice-mic { width: 42px; height: 42px; border-radius: 50%; background: var(--turquoise); border: 2px solid var(--gold); display: flex; align-items: center; justify-content: center; color: var(--bg-deep); flex-shrink: 0; }
.voice-mic i { font-size: 19px; }
.voice-bar-text { font-size: 13px; color: var(--ivory-mute); text-align: left; }
.card { background: var(--bg-card); border: 1px solid var(--bd); border-radius: 16px; padding: 13px 15px; }
.currency-row { display: flex; align-items: center; gap: 14px; }
.currency-cell { flex: 1; }
.currency-label { font-size: 11px; color: var(--ivory-mute); letter-spacing: 1.5px; }
.currency-value { font-family: var(--serif); font-size: 21px; margin-top: 2px; }
.currency-swap { color: var(--gold); font-size: 17px; }
.currency-detail { border-top: 1px solid var(--bd-soft); margin-top: 9px; padding-top: 8px; font-size: 11px; color: var(--ivory-low); text-align: center; }
.tools { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.tool { background: var(--bg-card); border: 1px solid var(--bd); border-radius: 14px; padding: 13px 13px; display: flex; align-items: center; gap: 11px; text-align: left; transition: all .2s; }
.tool:hover { border-color: var(--gold); background: rgba(10,40,38,0.7); }
.tool > i { color: var(--gold); font-size: 24px; flex-shrink: 0; }
.tool-title { font-size: 13px; color: var(--ivory); font-weight: 500; line-height: 1.2; }
.tool-sub { font-size: 11px; color: var(--ivory-low); margin-top: 3px; }
.tools .tool[data-tool="trip"] { grid-column: 1 / -1; justify-content: center; text-align: center; }
.rec-col { display: flex; flex-direction: column; padding: 16px; min-height: 0; }
.rec-head { display: flex; align-items: center; gap: 7px; font-size: 11px; letter-spacing: 2px; color: var(--gold); margin-bottom: 12px; flex-shrink: 0; }
.rec-head i { font-size: 14px; }
.dest-scroll { display: flex; flex-direction: column; gap: 11px; overflow-y: auto; overflow-x: hidden; scrollbar-width: thin; scrollbar-color: var(--bd) transparent; min-height: 0; padding-right: 4px; }
.dest-scroll::-webkit-scrollbar { width: 5px; }
.dest-scroll::-webkit-scrollbar-thumb { background: var(--bd); border-radius: 10px; }
.dest-scroll::-webkit-scrollbar-track { background: transparent; }
.dest-card { background: var(--bg-card); border: 1px solid var(--bd); border-radius: 14px; overflow: hidden; cursor: pointer; flex-shrink: 0; transition: all .2s; }
.dest-card:hover { border-color: var(--gold); background: rgba(10,40,38,0.72); transform: translateY(-2px); }
.dest-photo { width: 100%; height: 104px; object-fit: cover; object-position: center; position: relative; }
.dest-photo-wrap { position: relative; }
.dest-badge { position: absolute; top: 8px; left: 8px; background: var(--gold); color: var(--bg-deep); font-size: 11px; font-weight: 600; padding: 2px 9px; border-radius: 100px; letter-spacing: 0.5px; }
.dest-body { padding: 9px 12px 11px; }
.dest-title { font-family: var(--serif); font-size: 14px; color: var(--ivory); line-height: 1.2; }
.dest-short { font-size: 11px; color: var(--ivory-low); margin-top: 4px; line-height: 1.35; }

/* ===== DESKTOP: 3 columnas, sin scroll ===== */
@media (min-width: 900px) {
  html, body { overflow: hidden; }
  .app {
    display: grid;
    grid-template-columns: minmax(300px, 32%) 1fr 330px;
    gap: 16px;
    padding: 14px;
    height: 100dvh;
    overflow: hidden;
  }
  .img-col { height: 100%; border-radius: 20px; }
  .hero-img { border-radius: 20px; }
  .ctrl-col { justify-content: center; gap: 6px; padding: 6px 12px; overflow-y: auto; }
  .brand .logo { font-size: 28px; }
  .hero-thai { font-size: 17px; margin-bottom: 3px; }
  .hero-title { font-size: 30px; }
  .hero-sub { font-size: 13px; margin-top: 5px; }
  .currency-card { padding: 8px 16px; }
  .weather-card { margin-top: 0; padding: 8px 16px; }
  .tools { gap: 7px; }
  .tools .tool { padding: 7px 12px; }
  .rec-col { overflow: hidden; padding: 8px 4px 8px 12px; }
}


/* ===== MOVIL: apilado, carrusel horizontal al footer ===== */
@media (max-width: 899px) {
  html, body { overflow: auto; height: auto; }
  .app { min-height: 100dvh; overflow: visible; }
  .img-col { height: 170px; flex-shrink: 0; }
  .hero-img { border-radius: 0; }
  .ctrl-col { padding: 18px 16px 8px; }
  .rec-col { padding: 12px 0 28px; min-height: auto; overflow: visible; }
  .rec-head { padding: 0 16px; }
  .dest-scroll { flex-direction: row; overflow-x: auto; overflow-y: hidden; align-items: stretch; min-height: 0; padding: 4px 16px 14px; gap: 12px; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
  .dest-card { flex: 0 0 200px; width: 200px; scroll-snap-align: start; }
  .dest-card:hover { transform: none; }
}

/* === Conversor de divisas (versión integrada) === */
.currency-card{background:transparent;border:1px solid rgba(201,168,94,0.13);border-radius:18px;padding:22px 24px;color-scheme:dark}
.cur-grid{display:grid;grid-template-columns:1fr 52px 1fr;align-items:center;gap:6px}
.cur-cell{display:flex;flex-direction:column;gap:4px;min-width:0}
.cur-cur{display:flex;align-items:center;gap:6px}
.cur-flag{width:18px;height:18px;border-radius:50%;display:block;flex-shrink:0}
.cur-cur i{font-size:15px;color:var(--gold);pointer-events:none;margin-left:-2px}
.cur-to .cur-cur{justify-content:flex-end}
.cur-to .cur-val{text-align:right}
.cur-sel{appearance:none !important;-webkit-appearance:none !important;background:transparent !important;background-color:transparent !important;background-image:none !important;border:none !important;color:var(--gold) !important;font-family:var(--ui);font-size:14px;font-weight:500;letter-spacing:.08em;padding:0;cursor:pointer;outline:none;forced-color-adjust:none}
.cur-sel option{background:var(--bg-deep);color:var(--ivory)}
.cur-val{appearance:none !important;-webkit-appearance:none !important;background:transparent !important;background-color:transparent !important;border:none !important;border-bottom:1px solid transparent !important;color:var(--ivory) !important;-webkit-text-fill-color:var(--ivory);font-family:var(--ui);font-size:28px;font-weight:300;width:100%;padding:1px 0;outline:none;forced-color-adjust:none;box-shadow:none !important}
.cur-val:focus{border-bottom:1px solid rgba(201,168,94,0.4) !important;background:transparent !important}
.cur-val:-webkit-autofill,.cur-val:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px var(--bg-deep) inset !important;-webkit-text-fill-color:var(--ivory) !important;caret-color:var(--ivory)}
.cur-swap{width:40px;height:40px;border-radius:50%;background:rgba(111,198,211,0.10);border:1px solid rgba(111,198,211,0.32);color:var(--turquoise);display:flex;align-items:center;justify-content:center;cursor:pointer;margin:0 auto;font-size:18px;padding:0;forced-color-adjust:none}
.currency-detail{margin-top:9px;padding-top:9px;border-top:1px solid rgba(201,168,94,0.13);color:var(--ivory-mute);font-size:13px;font-weight:300}

/* === Clima TMD === */
.weather-card{background:transparent;border:1px solid rgba(111,198,211,0.16);border-radius:14px;padding:11px 16px;margin-top:10px;color-scheme:dark}
.wx-main{display:flex;align-items:center;gap:11px}
.wx-icon{font-size:26px;line-height:1;flex-shrink:0}
.wx-now{display:flex;flex-direction:column;gap:0;min-width:0}
.wx-temp{font-size:23px;font-weight:300;color:var(--ivory);line-height:1.05}
.wx-cond{font-size:12px;color:var(--ivory-mute);font-weight:300}
.wx-loc{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:0}
.wx-place{font-size:12px;color:var(--turquoise);font-weight:500;letter-spacing:.04em;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wx-meta{display:flex;flex-direction:column;justify-content:center;gap:2px;margin-left:14px;color:var(--ivory-mute);font-size:11.5px;font-weight:300}
.wx-meta span{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.wx-meta i{color:var(--turquoise);font-size:14px}
.weather-card.wx-status .wx-meta{display:none}
.weather-card.wx-status .wx-temp{color:var(--ivory-mute)}

/* === Mini-widget de clima dentro del detalle de cada ubicación === */
.wx-inline{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:12px;padding:10px 12px;border:1px solid rgba(111,198,211,0.18);border-radius:12px;color:var(--ivory-mute);font-size:13px}
.wx-inline-icon{font-size:20px;line-height:1}
.wx-inline-temp{font-size:18px;font-weight:300;color:var(--ivory)}
.wx-inline-cond{color:var(--ivory-mute)}
.wx-inline-meta{display:inline-flex;flex-wrap:wrap;align-items:center;gap:10px;margin-left:auto;font-size:11.5px}
.wx-inline-meta span{display:inline-flex;align-items:center;gap:4px}
.wx-inline-meta i{color:var(--turquoise);font-size:13px}
.wx-inline.wx-status .wx-inline-temp{color:var(--ivory-mute)}

/* === Conversor — ajustes móvil === */
@media (max-width: 899px){
  .currency-card{padding:16px 14px}
  .cur-grid{grid-template-columns:1fr 40px 1fr;gap:4px}
  .cur-cell{gap:3px}
  .cur-cur{gap:5px}
  .cur-flag{width:16px;height:16px}
  .cur-sel{font-size:13px}
  .cur-cur i{font-size:13px}
  .cur-val{font-size:24px !important}
  .cur-swap{width:34px;height:34px;font-size:15px}
  .currency-detail{font-size:12px;margin-top:14px;padding-top:12px}
  .weather-card{padding:9px 12px;margin-top:8px}
  .wx-main{gap:9px}
  .wx-icon{font-size:23px}
  .wx-temp{font-size:21px}
  .wx-place{max-width:84px}
  .wx-meta{font-size:10.5px;margin-left:10px}
}

/* ===== Modal genérico (reutilizable) ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(2,18,17,0.62);z-index:50;display:flex;justify-content:flex-end;opacity:0;pointer-events:none;transition:opacity .22s ease}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal-sheet{width:min(440px,94%);height:100%;background:var(--bg-deep);border-left:1px solid var(--bd);display:flex;flex-direction:column;transform:translateX(26px);transition:transform .22s ease;box-sizing:border-box}
.modal-overlay.open .modal-sheet{transform:translateX(0)}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 20px 14px;border-bottom:1px solid var(--bd-soft)}
.modal-title{font-family:var(--serif);font-size:21px;color:var(--ivory);line-height:1}
.modal-sub{font-size:12px;color:var(--ivory-low);margin-top:3px}
.modal-x{background:transparent;border:none;color:var(--ivory-mute);font-size:22px;cursor:pointer;line-height:1;padding:0}
.modal-body{flex:1;overflow-y:auto;padding:16px 20px 24px}
.ph-gender{display:flex;gap:8px;margin-bottom:14px}
.ph-gbtn{flex:1;font-family:var(--ui);font-size:13px;padding:7px;border-radius:10px;border:1px solid var(--bd);background:transparent;color:var(--ivory-mute);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}
.ph-gbtn.on{color:var(--gold);border-color:var(--gold);background:rgba(201,168,94,0.13)}
.ph-chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:12px;margin-bottom:4px}
.ph-chip{flex:0 0 auto;font-family:var(--ui);font-size:13px;padding:5px 13px;border-radius:20px;border:1px solid rgba(201,168,94,0.3);background:transparent;color:var(--gold);cursor:pointer;white-space:nowrap}
.ph-chip.on{border-color:var(--gold);background:rgba(201,168,94,0.15);font-weight:500}
.ph-row{display:flex;align-items:center;gap:12px;padding:13px 2px;border-top:1px solid rgba(201,168,94,0.13)}
.ph-row:first-child{border-top:none}
.ph-txt{flex:1;min-width:0}
.ph-es{font-size:15px;color:var(--ivory);line-height:1.25}
.ph-th{font-size:18px;color:var(--ivory);margin-top:3px;font-weight:300}
.ph-ph{font-size:13px;color:var(--gold);font-style:italic;margin-top:1px}
.ph-play{flex:0 0 auto;width:40px;height:40px;border-radius:50%;border:1px solid var(--turquoise);background:transparent;color:var(--turquoise);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px}
.ph-play:active{transform:scale(.94)}
.ph-note{font-size:11px;color:var(--ivory-low);margin-top:12px;display:none}

@media (max-width:899px){
  .modal-overlay{justify-content:center;align-items:flex-end}
  .modal-sheet{width:100%;height:auto;max-height:88dvh;border-left:none;border-top:1px solid var(--bd);border-radius:18px 18px 0 0;transform:translateY(28px)}
  .modal-overlay.open .modal-sheet{transform:translateY(0)}
}

/* ===== Teléfonos ===== */
/* telefonos redesign */
.tel-sec{margin-bottom:20px}
.tel-sec-h{font-family:var(--ui);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin:0 0 10px}
.tel-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tel-card{position:relative;display:block;text-decoration:none;background:rgba(255,255,255,0.04);border:1px solid rgba(201,168,94,0.18);border-radius:14px;padding:13px 14px}
.tel-card:active{transform:scale(.97)}
.tel-card-num{font-family:var(--ui);font-size:26px;font-weight:500;color:var(--turquoise);line-height:1}
.tel-card-label{font-size:12.5px;color:var(--ivory);margin-top:6px;line-height:1.2}
.tel-card-hint{font-size:11px;color:var(--ivory-low);margin-top:2px;line-height:1.2}
.tel-card-ic{position:absolute;top:11px;right:12px;color:rgba(111,198,211,0.45);font-size:14px}
.tel-li{display:flex;align-items:center;gap:12px;padding:11px 2px;border-top:1px solid rgba(201,168,94,0.12)}
.tel-li:first-of-type{border-top:none}
.tel-li-main{flex:1;min-width:0}
.tel-li-name{font-size:15px;color:var(--ivory);line-height:1.2}
.tel-li-hint{font-size:11.5px;color:var(--ivory-low);margin-top:1px}
.tel-li-r{flex:0 0 auto;display:flex;align-items:center;gap:12px}
.tel-li-num{font-family:var(--ui);font-size:17px;color:var(--turquoise)}
.tel-emb{display:flex;align-items:center;gap:12px;padding:11px 2px;border-top:1px solid rgba(201,168,94,0.12)}
.tel-emb:first-of-type{border-top:none}
.tel-emb-flag{flex:0 0 auto;width:20px;height:20px;border-radius:50%}
.tel-emb-main{flex:1;min-width:0}
.tel-emb-name{font-size:15px;color:var(--ivory);line-height:1.2}
.tel-emb-num{font-size:13.5px;color:var(--turquoise);margin-top:1px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.tel-emb-badge{font-size:10px;color:var(--gold);border:1px solid rgba(201,168,94,0.45);border-radius:10px;padding:1px 6px;font-family:var(--ui)}
.tel-emb-subrow{display:flex;align-items:center;gap:10px;margin-top:8px;padding-left:32px}
.tel-emb-sub{flex:1;min-width:0;font-size:12px;color:var(--gold)}
.tel-emb-sub-num{color:var(--ivory-mute)}
.tel-call{flex:0 0 auto;width:38px;height:38px;border-radius:50%;border:1px solid var(--turquoise);background:transparent;color:var(--turquoise);display:flex;align-items:center;justify-content:center;font-size:17px;text-decoration:none}
.tel-call:active{transform:scale(.94)}
.tel-call-sm{flex:0 0 auto;width:32px;height:32px;border-radius:50%;border:1px solid var(--gold);background:transparent;color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:14px;text-decoration:none}
.tel-note{font-size:11px;color:var(--ivory-low);margin-top:6px;line-height:1.4}
/* recomendados - detalle */
.dest-card{cursor:pointer}
.place-photo-wrap{position:relative;width:100%;aspect-ratio:16/10;border-radius:14px;overflow:hidden;background:#0a2926;border:1px solid rgba(201,168,94,0.15)}
.place-photo{width:100%;height:100%;object-fit:cover;display:block}
.place-badge{position:absolute;top:12px;left:12px;background:rgba(5,51,48,0.82);color:var(--gold);font-family:var(--ui);font-size:11px;letter-spacing:.1em;padding:4px 11px;border-radius:20px;border:1px solid rgba(201,168,94,0.4)}
.place-desc{font-size:14.5px;line-height:1.62;color:rgba(243,240,231,0.9);margin:16px 0 18px}
.place-cta{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--gold);color:var(--gold);border-radius:24px;padding:10px 18px;font-size:14px;text-decoration:none}
.place-cta:active{transform:scale(.96)}
.place-cta-aff{background:var(--gold);color:#0a2926;font-weight:600;border-color:var(--gold);margin-right:10px}
/* Antes de viajar (affiliate.js) */
.trip-list{display:flex;flex-direction:column;gap:14px}
.trip-item{display:flex;gap:13px;align-items:flex-start;background:var(--bg-card);border:1px solid var(--bd);border-radius:14px;padding:14px}
.trip-ico{flex-shrink:0;width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:rgba(201,168,94,0.1);border:1px solid var(--bd-soft)}
.trip-ico i{color:var(--gold);font-size:22px}
.trip-body{flex:1;min-width:0}
.trip-t{font-size:15px;font-weight:600;color:var(--ivory);line-height:1.25}
.trip-d{font-size:13px;color:var(--ivory-mute);line-height:1.5;margin:5px 0 11px}
.trip-cta{padding:8px 15px;font-size:13.5px}
.trip-warn{display:flex;gap:7px;align-items:flex-start;font-size:12px;color:var(--ivory-low);line-height:1.45;margin:12px 2px 4px}
.trip-warn i{color:var(--gold);flex-shrink:0;margin-top:1px}

/* ── Legal footer + docs ─── */
.legal-footer{display:flex;justify-content:center;align-items:center;gap:14px;padding:28px 16px 24px;font-size:12px;color:var(--ivory-low);flex-wrap:wrap;border-top:1px solid var(--bd-soft);margin-top:32px}
.legal-footer a{color:var(--ivory-low);text-decoration:none;cursor:pointer;transition:color .15s}
.legal-footer a:hover{color:var(--gold)}
.legal-footer .sep{opacity:.4}
.legal-footer .version{width:100%;text-align:center;font-size:10px;opacity:.45;margin-top:4px;font-family:monospace}
.legal-doc{font-size:14px;line-height:1.6;color:var(--ivory)}
.legal-doc p{margin:0 0 12px}
.legal-doc ul{margin:0 0 14px;padding-left:20px}
.legal-doc li{margin-bottom:6px;line-height:1.55}
.legal-doc strong{color:var(--gold);font-weight:500}
.legal-doc code{background:rgba(201,168,94,.12);color:var(--gold);padding:1px 6px;border-radius:3px;font-size:.9em;font-family:monospace}

/* Footer dentro de .app: ocupa fila completa en desktop */
.legal-footer{margin-top:0}
@media (min-width: 900px){
  .app{grid-template-rows:1fr auto}
  .legal-footer{grid-column:1 / -1;padding:10px 16px 14px;font-size:11px;gap:12px}
  .legal-footer .version{margin-top:2px}
}
@media (max-width: 899px){
  .legal-footer{margin-top:16px}
}

/* Footer compacto en desktop, una sola línea */
@media (min-width: 900px){
  .legal-footer{padding:6px 16px 8px;font-size:11px;gap:14px;flex-wrap:nowrap}
}

/* === Beta gate: teaser + toast === */
.beta-teaser{text-align:center;padding:4px 0}
.bt-cta{color:#94a3b8;font-size:13px;margin:0 0 6px}
.bt-offer{color:var(--turquoise);font-size:13px;margin:0 0 2px}
.bt-reward{color:var(--gold);font-size:15px;font-weight:700;margin:0 0 16px}
.bt-email{width:100%;padding:12px;border-radius:10px;border:2px solid rgba(255,255,255,.12);background:rgba(0,0,0,.3);color:#fff;font-size:14px;box-sizing:border-box;margin-bottom:10px;outline:none;transition:border-color .2s}
.bt-email:focus{border-color:var(--laguna)}
.bt-btn{width:100%;padding:12px;border-radius:10px;border:none;background:var(--laguna);color:#fff;font-size:14px;font-weight:700;cursor:pointer}
.bt-skip{width:100%;padding:8px;border:none;background:transparent;color:#64748b;font-size:12px;cursor:pointer;margin-top:4px}
.beta-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--laguna);color:#fff;padding:10px 20px;border-radius:10px;font-size:13px;font-weight:600;z-index:10001;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none}
.beta-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* === Menu scanner === */
.mn-warn{background:#fef3c7;border-radius:8px;padding:8px 10px;font-size:11px;color:#92400e;line-height:1.4;margin-bottom:12px}
.mn-list{display:flex;flex-direction:column;gap:8px}
.mn-dish{background:rgba(0,0,0,.2);border-radius:10px;padding:12px}
.mn-dish-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.mn-dish-info{flex:1;min-width:0}
.mn-original{font-size:14px;font-weight:700;color:#fff}
.mn-translation{font-size:13px;font-weight:600;color:var(--turquoise);margin-top:2px}
.mn-translit{font-size:11px;color:#94a3b8;margin-top:2px;font-style:italic}
.mn-dish-warn{font-size:11px;color:#fbbf24;margin-top:4px}
.mn-price{background:var(--gold);color:#1a1a2e;font-size:12px;font-weight:700;padding:4px 8px;border-radius:6px;white-space:nowrap;align-self:flex-start}
.mn-badges{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.mn-badge{font-size:10px;padding:3px 7px;border-radius:6px;font-weight:600;color:#fff;background:#dc2626}
.mn-badge-allergen{background:#7c3aed}
.mn-badge-green{background:#059669}
.mn-empty{color:#94a3b8;text-align:center;padding:20px 0;font-size:13px}
.mn-loading{text-align:center;padding:30px 0;color:#94a3b8;font-size:13px}
.mn-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--turquoise);border-radius:50%;animation:mn-spin .8s linear infinite;margin:0 auto 12px}
@keyframes mn-spin{to{transform:rotate(360deg)}}

/* === Sign Translator === */
.sg-warn{background:#fef3c7;border-radius:8px;padding:8px 10px;font-size:11px;color:#92400e;line-height:1.4;margin-bottom:12px}
.sg-canvas-wrap{width:100%;overflow:hidden;border-radius:10px;margin-bottom:12px}
.sg-canvas{width:100%;display:block;border-radius:10px}
.sg-save{display:inline-block;padding:8px 16px;background:var(--turquoise);color:#fff;border-radius:8px;text-decoration:none;font-size:13px;font-weight:600;margin:8px 0 16px}
.sg-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.sg-row{display:flex;align-items:center;gap:6px;font-size:13px;padding:6px 8px;background:rgba(255,255,255,.06);border-radius:6px}
.sg-orig{color:var(--gold);flex:1}
.sg-arrow{color:#888;font-size:11px}
.sg-tr{flex:1;color:#fff}
.sg-empty{text-align:center;color:#aaa;padding:24px 0}
.sg-loading{text-align:center;padding:32px 0;color:#ccc}

/* === Translator === */
.tr-dir{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:13px;font-weight:700;color:var(--gold)}
.tr-swap{background:rgba(255,255,255,.08);border:0;border-radius:8px;padding:6px 10px;color:#fff;cursor:pointer}
.tr-input-row{display:flex;gap:8px;align-items:stretch}
.tr-ta{flex:1;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:10px;color:#fff;padding:10px;font-size:15px;resize:vertical;min-height:72px}
.tr-mic{width:52px;background:rgba(255,255,255,.08);border:0;border-radius:10px;color:#fff;font-size:20px;cursor:pointer}
.tr-mic-on{background:#ef4444;animation:trPulse 1s infinite}
@keyframes trPulse{50%{opacity:.6}}
.tr-go{width:100%;margin-top:10px;padding:11px;background:var(--turquoise);border:0;border-radius:10px;color:#fff;font-size:15px;font-weight:700;cursor:pointer}
.tr-go:disabled{opacity:.5}
.tr-result{margin-top:14px}
.tr-warn{background:#fef3c7;border-radius:8px;padding:8px 10px;font-size:12px;color:#92400e;margin-bottom:10px;font-weight:600}
.tr-target{font-size:26px;line-height:1.4;color:#fff;font-weight:600;margin-bottom:6px;word-break:break-word}
.tr-translit{font-size:14px;color:var(--gold);font-style:italic;margin-bottom:8px}
.tr-back{font-size:12px;color:#aaa;margin-bottom:12px}
.tr-back-label{font-weight:700;color:#888}
.tr-copy{padding:8px 16px;background:rgba(255,255,255,.1);border:0;border-radius:8px;color:#fff;font-size:13px;cursor:pointer}
.tr-actions{display:flex;gap:8px;margin-top:4px}
.tr-play{padding:8px 16px;background:var(--turquoise);border:0;border-radius:8px;color:#fff;font-size:13px;font-weight:600;cursor:pointer}
.tr-loading{text-align:center;padding:20px 0;color:#ccc}
.tr-history{margin-top:16px}
.tr-hist-head{display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:700;color:var(--gold);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.tr-hist-clear{background:none;border:0;color:#888;font-size:12px;cursor:pointer;text-decoration:underline}
.tr-hist-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-top:1px solid rgba(255,255,255,.07)}
.tr-hist-txt{flex:1;min-width:0}
.tr-hist-src{font-size:12px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tr-hist-tgt{font-size:16px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tr-hist-play{background:rgba(255,255,255,.08);border:0;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:15px;flex-shrink:0}
