/* ════ TRIPPY DESIGN TOKENS ════ */
:root{
  --bg:#07070F; --bg-2:#0C0C1A; --bg-3:#111124;
  --surface:rgba(255,255,255,0.03); --surface-2:rgba(255,255,255,0.06);
  --border:rgba(255,255,255,0.07); --border-2:rgba(255,255,255,0.14);
  --text:#ECEAF6; --text-2:#B0AECE; --text-3:#7A7698;
  --cyan:#00DDB8; --cyan-dim:rgba(0,221,184,0.08); --cyan-bd:rgba(0,221,184,0.20);
  --violet:#7C5CF6; --pink:#E879A8; --gold:#F5A623; --green:#34D399; --red:#FF5757;
  --head:'Space Grotesk',sans-serif; --mono:'Space Mono',monospace;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{background:var(--bg);color:var(--text);font-family:var(--head);font-size:16px;overflow-x:hidden}
input,select,button,textarea{font-family:inherit;color:inherit}
button{cursor:pointer;background:none;border:none}
::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:99px}
input[type=number]{-moz-appearance:textfield}
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}
input[type=date]::-webkit-calendar-picker-indicator,input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.6) sepia(1) hue-rotate(115deg) saturate(3)}

@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}

/* ════ APP SHELL ════ */
#app{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative;background:var(--bg)}
@media(min-width:520px){#app{border-left:1px solid var(--border);border-right:1px solid var(--border)}}
.screen{flex:1;display:flex;flex-direction:column;animation:fadeIn .2s ease}
.scroll{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px;padding-bottom:120px}

/* typography */
.micro{font-family:var(--mono);font-size:10px;letter-spacing:1.6px;color:var(--cyan);text-transform:uppercase}
.micro.dim{color:var(--text-3)}
.muted{font-family:var(--mono);font-size:10px;color:var(--text-3)}

/* header */
.apphead{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:rgba(7,7,15,.92);backdrop-filter:blur(16px);z-index:20}
.backbtn{font-size:20px;color:var(--text);padding:0 4px;line-height:1}
.apphead .ttl{flex:1;min-width:0}
.apphead .ttl .nm{font-size:16px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apphead .ttl .dt{font-family:var(--mono);font-size:9px;color:var(--text-3);margin-top:1px;letter-spacing:.5px}
.logo{font-weight:700;font-size:18px;letter-spacing:4px;color:var(--cyan)}
.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;border:1px solid rgba(52,211,153,.27);background:var(--surface);font-family:var(--mono);font-size:8px;letter-spacing:1px;color:var(--green);text-transform:uppercase}
.pill .pd{width:5px;height:5px;border-radius:3px;background:var(--green)}
.pill.off{border-color:rgba(245,166,35,.27);color:var(--gold)}
.pill.off .pd{background:var(--gold)}
.iconbtn{width:34px;height:34px;border-radius:8px;border:1px solid var(--cyan-bd);background:var(--cyan-dim);display:flex;align-items:center;justify-content:center;color:var(--cyan);font-size:15px;flex-shrink:0}
.iconbtn.ghost{border-color:var(--border);background:var(--surface);color:var(--text-3)}

/* cards */
.card{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;padding:15px;animation:fadeUp .3s ease both}
.card.term{background:var(--bg-3)}
.bar{height:6px;border-radius:3px;background:var(--surface-2);overflow:hidden}
.bar i{display:block;height:100%;border-radius:3px;background:var(--cyan);transition:width .6s ease}

/* trips home */
.tagline{font-size:27px;font-weight:600;line-height:1.25}
.tagline .c{color:var(--cyan)}
.home-visual{height:74px;display:flex;align-items:center;justify-content:center;gap:10px;margin:2px 0 4px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(135deg,rgba(97,226,255,.10),rgba(145,242,201,.05),rgba(255,255,255,.02));box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 18px 44px rgba(0,0,0,.22);overflow:hidden;position:relative}
.home-visual:before{content:"";position:absolute;inset:-40%;background:radial-gradient(circle at 30% 40%,rgba(97,226,255,.20),transparent 28%),radial-gradient(circle at 70% 55%,rgba(145,242,201,.14),transparent 24%);filter:blur(2px)}
.hv-node{width:13px;height:13px;border-radius:50%;position:relative;z-index:1;background:var(--cyan);box-shadow:0 0 0 6px rgba(97,226,255,.10),0 0 22px rgba(97,226,255,.65)}
.hv-node.b{width:18px;height:18px;background:#91f2c9;box-shadow:0 0 0 8px rgba(145,242,201,.10),0 0 28px rgba(145,242,201,.65)}
.hv-node.c{background:#ffd166;box-shadow:0 0 0 6px rgba(255,209,102,.10),0 0 22px rgba(255,209,102,.55)}
.hv-line{width:64px;height:1px;position:relative;z-index:1;background:linear-gradient(90deg,transparent,rgba(255,255,255,.38),transparent)}
.tripcard{display:flex;align-items:center;gap:13px;background:var(--bg-2);border:1px solid var(--border);border-radius:16px;padding:15px;cursor:pointer;transition:border-color .2s;animation:fadeUp .3s ease both}
.tripcard:hover{border-color:var(--cyan-bd)}
.tripcard .accent{width:3px;align-self:stretch;border-radius:2px;flex-shrink:0}
.tripcard .mid{flex:1;display:flex;flex-direction:column;gap:7px;min-width:0}
.trow{display:flex;justify-content:space-between;align-items:center;gap:8px}
.tstat{font-family:var(--mono);font-size:9px;letter-spacing:1.2px}
.tdate{font-family:var(--mono);font-size:9px;color:var(--text-3)}
.tname{font-size:17px;font-weight:600}
.tmoney{font-family:var(--mono);font-size:11px}
.tmoney small{font-size:9px;color:var(--text-3)}
.xbtn{color:var(--text-3);font-size:14px;padding:6px;line-height:1;flex-shrink:0;border-radius:6px}
.xbtn:hover{color:var(--red);background:rgba(255,87,87,.08)}

/* terminal */
.tdots{display:flex;gap:4px}
.tdots i{width:9px;height:9px;border-radius:5px;display:block}
.term-ttl{font-family:var(--mono);font-size:10px;color:var(--text-3)}
.tline{display:flex;font-family:var(--mono);font-size:12px;margin-top:8px}
.tline .k{color:var(--text-3);width:96px;flex-shrink:0}

/* stats */
.statgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.statcell{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:14px;animation:fadeUp .3s ease both}
.statcell .v{font-size:18px;font-weight:600}
.statcell .l{font-family:var(--mono);font-size:8px;letter-spacing:1.2px;color:var(--text-3);margin-top:4px;text-transform:uppercase}

/* route */
.routerow{display:flex;align-items:center;gap:10px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:12px 14px;border-left:2px solid var(--cyan)}
.routerow .nm{font-size:14px;font-weight:600;flex:1;min-width:0}
.routerow .nm small{display:block;font-family:var(--mono);font-size:9px;color:var(--text-3);font-weight:400;margin-top:2px}
.routerow .bj{font-family:var(--mono);font-size:10px;color:var(--text-2)}

/* chips */
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-family:var(--mono);font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);border:1px solid var(--border);background:var(--surface);border-radius:999px;padding:7px 13px;transition:all .15s}
.chip.on{color:var(--cyan);border-color:var(--cyan);background:var(--cyan-dim)}

/* donut */
.donutwrap{display:flex;flex-direction:column;align-items:center;gap:14px;padding:8px 0 2px}
.donut{width:160px;height:160px;border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center;animation:popIn .4s ease both}
.donut::before{content:'';position:absolute;inset:28px;background:var(--bg-2);border-radius:50%}
.donut .ctr{position:relative;text-align:center;z-index:1}
.donut .ctr b{font-size:18px;font-weight:600;display:block}
.donut .ctr s{font-family:var(--mono);font-size:8px;letter-spacing:1px;color:var(--text-3);text-decoration:none;text-transform:uppercase}
.legend{width:100%;display:flex;flex-direction:column;gap:7px}
.lrow{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--text-2)}
.lrow .d{width:7px;height:7px;border-radius:4px;flex-shrink:0}
.lrow .p{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--text-3)}

/* expenses */
.exp{display:flex;align-items:center;gap:11px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:12px 13px;animation:fadeUp .25s ease both}
.exp .ci{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.exp .ti{flex:1;min-width:0}
.exp .ti b{font-size:13px;font-weight:500;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.exp .ti small{font-family:var(--mono);font-size:8.5px;color:var(--text-3)}
.exp .am{text-align:right;font-family:var(--mono);font-size:11.5px;flex-shrink:0}
.exp .am small{display:block;font-size:8.5px;color:var(--text-3);margin-top:1px}

/* itinerary */
.dayhead{font-family:var(--mono);font-size:9px;letter-spacing:1.4px;color:var(--text-3);text-transform:uppercase;padding:6px 0 0}
.dayhead.today{color:var(--cyan)}
.it{display:flex;align-items:center;gap:10px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:11px 12px;cursor:pointer;animation:fadeUp .25s ease both}
.it.done{opacity:.45}
.it .ki{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.it .ti{flex:1;min-width:0;font-size:13px}
.it.done .ti{text-decoration:line-through;color:var(--text-3)}
.it .ti small{display:block;font-family:var(--mono);font-size:8.5px;color:var(--text-3);text-decoration:none}
.it .tm{font-family:var(--mono);font-size:10px;color:var(--text-2);flex-shrink:0}
.it .ck{font-size:16px;color:var(--text-3);flex-shrink:0}
.it.done .ck{color:var(--green)}
.freeday{font-family:var(--mono);font-size:9px;color:rgba(122,118,152,.55);padding:2px 4px 6px}

/* packing */
.packsum{position:sticky;top:63px;background:rgba(7,7,15,.92);backdrop-filter:blur(12px);padding:12px 0 12px;z-index:10;display:flex;flex-direction:column;gap:9px}
.sect{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:9px;letter-spacing:1.4px;color:var(--text-3);text-transform:uppercase;padding:8px 0 2px}
.pk{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px solid var(--border);font-size:14px;cursor:pointer}
.pk .bx{width:18px;height:18px;border:1.5px solid var(--text-3);border-radius:5px;flex-shrink:0;position:relative;transition:all .15s}
.pk.ckd .bx{background:var(--cyan);border-color:var(--cyan)}
.pk.ckd .bx::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--bg);font-weight:700}
.pk.ckd .pname{text-decoration:line-through;color:var(--text-3)}
.pk .pname{flex:1;min-width:0}
.pk .q{font-family:var(--mono);font-size:9px;color:var(--text-3)}

/* split */
.balrow{display:flex;align-items:center;gap:12px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:12px 13px;animation:fadeUp .25s ease both}
.av{width:34px;height:34px;border-radius:17px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:700;font-size:10px;flex-shrink:0}
.balrow .nm{flex:1;min-width:0}
.balrow .nm b{font-size:14px;font-weight:500;display:block}
.balrow .nm small{font-family:var(--mono);font-size:8.5px;color:var(--text-3);text-transform:uppercase}
.balamt{font-family:var(--mono);font-size:12px;flex-shrink:0}
.settle{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:13px 14px;animation:fadeUp .25s ease both}
.settle .f{font-weight:600;font-size:13px;color:var(--red)}
.settle .t{font-weight:600;font-size:13px;color:var(--green);text-align:right}
.settle .m{font-family:var(--mono);font-size:11px;display:flex;align-items:center;gap:7px}
.settle .m .ar{color:var(--cyan)}
.shint{font-family:var(--mono);font-size:8.5px;color:var(--text-3);text-align:center;padding-top:2px}
.addrow{display:flex;gap:9px}
.addrow input{flex:1}

/* currency */
.cvamt{display:flex;align-items:baseline;gap:10px}
.cvamt input{flex:1;background:none;border:none;outline:none;font-family:var(--head);font-size:30px;font-weight:600;color:var(--text);min-width:0}
.cvamt .res{flex:1;font-size:30px;font-weight:600;color:var(--cyan);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cvamt .cd{font-family:var(--mono);font-size:15px;color:var(--text-3);flex-shrink:0}
.swaprow{display:flex;align-items:center;gap:10px;margin:12px 0}
.swaprow .ln{flex:1;height:1px;background:var(--border)}
.swapbtn{width:36px;height:36px;border-radius:18px;border:1px solid var(--cyan-bd);background:var(--cyan-dim);display:flex;align-items:center;justify-content:center;color:var(--cyan);font-size:15px}
.rateline{font-family:var(--mono);font-size:10px;color:var(--text-3);text-align:center;margin-top:10px}
.raterow{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:12px;cursor:pointer}
.raterow:last-child{border-bottom:none}
.raterow .cd2{font-family:var(--mono);font-weight:700;font-size:11px;width:42px;flex-shrink:0}
.raterow .nm{flex:1;color:var(--text-3);font-size:11px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.raterow .v{font-family:var(--mono);font-size:11px;color:var(--text-2)}
.srcnote{font-family:var(--mono);font-size:8.5px;letter-spacing:1px;color:rgba(0,221,184,.45);text-align:center;padding:6px 0}

/* tab bar */
.tabbar{position:sticky;bottom:0;display:flex;border-top:1px solid var(--border);background:rgba(12,12,26,.96);backdrop-filter:blur(16px);padding:9px 4px calc(10px + env(safe-area-inset-bottom));z-index:30}
.tab{flex:1;text-align:center;font-family:var(--mono);font-size:8px;letter-spacing:.5px;color:var(--text-3);text-transform:uppercase;display:flex;flex-direction:column;gap:4px;align-items:center;padding:2px 0}
.tab .ic{font-size:15px;line-height:1;filter:grayscale(1);opacity:.55;transition:all .15s}
.tab.on{color:var(--cyan)}
.tab.on .ic{filter:none;opacity:1}

/* FAB */
.fab{position:fixed;right:max(16px,calc(50% - 224px));bottom:84px;width:54px;height:54px;border-radius:27px;background:var(--cyan);color:var(--bg);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:500;box-shadow:0 8px 28px rgba(0,221,184,.35);z-index:40;transition:transform .15s}
.fab:active{transform:scale(.92)}
.fab.home{bottom:24px}

/* bottom sheet */
#overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:90;display:none;animation:fadeIn .2s ease}
#overlay.show{display:block}
#sheet{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:480px;background:var(--bg-2);border:1px solid var(--border-2);border-bottom:none;border-radius:20px 20px 0 0;padding:16px;max-height:88dvh;overflow-y:auto;z-index:100;display:none}
#sheet.show{display:block;animation:sheetUp .25s ease}
.handle{width:38px;height:4px;border-radius:2px;background:var(--border-2);margin:0 auto 16px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:13px}
.field label{font-family:var(--mono);font-size:9px;letter-spacing:1.4px;color:var(--text-3);text-transform:uppercase}
.inp{background:var(--bg-3);border:1px solid var(--border);border-radius:9px;padding:12px 14px;color:var(--text);font-size:15px;outline:none;width:100%;transition:border-color .15s;color-scheme:dark}
.inp:focus{border-color:var(--cyan-bd)}
.row2{display:flex;gap:10px}
.row2>*{flex:1;min-width:0}
.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:9px;font-family:var(--head);font-size:14px;font-weight:600;letter-spacing:.3px;transition:all .15s;width:100%}
.btn.pri{background:var(--cyan);color:var(--bg)}
.btn.pri:active{transform:scale(.98)}
.btn.gho{background:transparent;border:1px solid var(--border-2);color:var(--text)}
.btn.sm{width:auto;padding:11px 18px;font-size:12px}
.errtxt{font-family:var(--mono);font-size:11px;color:var(--red);margin-bottom:12px;display:none}
.errtxt.show{display:block}
.destdraft{background:var(--bg-3);border:1px solid var(--border);border-radius:10px;padding:11px;margin-bottom:9px;display:flex;flex-direction:column;gap:8px}
.empty{display:flex;flex-direction:column;align-items:center;gap:9px;padding:44px 20px;text-align:center}
.empty .gl{font-family:var(--mono);font-size:28px;color:rgba(0,221,184,.35)}
.empty .t1{font-size:17px;font-weight:600}
.empty .t2{font-size:13px;color:var(--text-3);max-width:250px;line-height:1.5}

/* toast */
#toast{position:fixed;left:50%;bottom:100px;transform:translateX(-50%);background:var(--bg-3);border:1px solid var(--cyan-bd);color:var(--text);font-family:var(--mono);font-size:11px;letter-spacing:.5px;padding:11px 20px;border-radius:99px;z-index:200;opacity:0;pointer-events:none;transition:opacity .25s;white-space:nowrap}
#toast.show{opacity:1}


/* ════ TRIPPY UI UPGRADE v2 — premium travel cockpit ════ */
:root{
  --bg:#05060A; --bg-2:rgba(15,18,28,.78); --bg-3:rgba(20,24,38,.88);
  --surface:rgba(255,255,255,.055); --surface-2:rgba(255,255,255,.092);
  --border:rgba(255,255,255,.105); --border-2:rgba(255,255,255,.18);
  --text:#F7F4EC; --text-2:#C9C3B6; --text-3:#8F8A82;
  --cyan:#3FE7C2; --cyan-dim:rgba(63,231,194,.105); --cyan-bd:rgba(63,231,194,.28);
  --violet:#9A7CFF; --pink:#FF7FAE; --gold:#FFC260; --green:#54E0A4; --red:#FF6565;
  --shadow-soft:0 18px 60px rgba(0,0,0,.34);
  --shadow-card:0 1px 0 rgba(255,255,255,.06) inset, 0 18px 45px rgba(0,0,0,.28);
}
html{background:#05060A}
body{
  background:
    radial-gradient(circle at 18% -6%, rgba(63,231,194,.24), transparent 34%),
    radial-gradient(circle at 92% 8%, rgba(154,124,255,.22), transparent 30%),
    radial-gradient(circle at 50% 115%, rgba(255,194,96,.12), transparent 35%),
    linear-gradient(180deg,#05060A 0%,#090B13 52%,#05060A 100%);
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.28;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:38px 38px;mask-image:linear-gradient(to bottom,black,transparent 78%);
}
#app{
  z-index:1;overflow:hidden;background:linear-gradient(180deg,rgba(8,9,16,.92),rgba(6,7,12,.96));
  box-shadow:0 0 0 1px rgba(255,255,255,.08),0 35px 90px rgba(0,0,0,.42);
}
#app::before{
  content:'';position:absolute;inset:-120px -90px auto -90px;height:300px;pointer-events:none;z-index:-1;
  background:radial-gradient(circle at 50% 0%,rgba(63,231,194,.22),transparent 58%);
  filter:blur(10px);
}
.scroll{gap:16px;padding:18px 16px 128px}.screen{animation:fadeIn .22s ease}.micro{font-weight:700;color:var(--cyan);text-shadow:0 0 18px rgba(63,231,194,.18)}
.apphead{
  padding:15px 16px;background:rgba(5,6,10,.74);backdrop-filter:blur(22px) saturate(1.25);
  border-bottom:1px solid rgba(255,255,255,.09);box-shadow:0 10px 30px rgba(0,0,0,.18)
}
.logo{
  letter-spacing:5px;background:linear-gradient(90deg,#F7F4EC 0%,#3FE7C2 55%,#9A7CFF 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 28px rgba(63,231,194,.20)
}
.pill{background:rgba(84,224,164,.095);border-color:rgba(84,224,164,.30);box-shadow:0 0 0 1px rgba(255,255,255,.035) inset}.pill.off{background:rgba(255,194,96,.10)}
.tagline{font-size:31px;line-height:1.12;letter-spacing:-.7px;max-width:360px}.tagline .c{background:linear-gradient(90deg,var(--cyan),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.card,.statcell,.routerow,.exp,.itrow,.packrow,.settle,.conv{
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.105);box-shadow:var(--shadow-card);backdrop-filter:blur(18px);border-radius:18px
}
.card.term{background:linear-gradient(180deg,rgba(16,19,31,.92),rgba(9,11,18,.88));border-color:rgba(63,231,194,.16)}
.tripcard{
  position:relative;isolation:isolate;overflow:hidden;padding:17px 15px;border-radius:22px;
  background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.13);box-shadow:var(--shadow-card);backdrop-filter:blur(20px);
  transform:translateZ(0);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease
}
.tripcard::before{content:'';position:absolute;inset:0;z-index:-1;background:radial-gradient(circle at 80% 10%,rgba(63,231,194,.14),transparent 34%),radial-gradient(circle at 0% 100%,rgba(154,124,255,.11),transparent 34%)}
.tripcard:hover{transform:translateY(-2px);border-color:rgba(63,231,194,.32);box-shadow:0 1px 0 rgba(255,255,255,.08) inset,0 24px 60px rgba(0,0,0,.36)}
.tripcard .accent{width:4px;border-radius:99px;box-shadow:0 0 22px currentColor}.tname{font-size:18px;letter-spacing:-.22px}.tmoney{font-size:12px;color:#F7F4EC}.bar{height:7px;background:rgba(255,255,255,.08)}.bar i{box-shadow:0 0 18px rgba(63,231,194,.32)}
.iconbtn,.fab,.btn{
  transition:transform .16s ease,filter .16s ease,box-shadow .16s ease,border-color .16s ease;
  box-shadow:0 10px 25px rgba(0,0,0,.22),0 0 0 1px rgba(255,255,255,.04) inset
}
.iconbtn{border-radius:12px;background:rgba(63,231,194,.10)}.iconbtn:hover,.btn:hover,.fab:hover{transform:translateY(-1px);filter:brightness(1.08)}
.fab{background:linear-gradient(135deg,var(--cyan),var(--violet));color:#05060A;font-weight:800;box-shadow:0 18px 42px rgba(63,231,194,.22),0 12px 36px rgba(154,124,255,.20)}
.btn:not(.gho){background:linear-gradient(135deg,var(--cyan),#9FFFEA);color:#07100E;font-weight:800;border:0}.btn.gho{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12)}
.chip{border-radius:999px;background:rgba(255,255,255,.045);border-color:rgba(255,255,255,.10)}.chip.on{background:linear-gradient(135deg,rgba(63,231,194,.16),rgba(154,124,255,.12));box-shadow:0 0 0 1px rgba(63,231,194,.20) inset}
input,select,textarea{background:rgba(255,255,255,.07)!important;border-color:rgba(255,255,255,.13)!important;border-radius:13px!important}input:focus,select:focus,textarea:focus{outline:none;border-color:rgba(63,231,194,.45)!important;box-shadow:0 0 0 3px rgba(63,231,194,.10)}
.toast{background:rgba(15,18,28,.86)!important;border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(18px);box-shadow:var(--shadow-soft)}
.sheet{background:rgba(5,6,10,.52)!important;backdrop-filter:blur(8px)}.sheet .box{background:linear-gradient(180deg,rgba(20,24,38,.96),rgba(8,10,17,.98));border:1px solid rgba(255,255,255,.12);box-shadow:0 -24px 70px rgba(0,0,0,.45)}
@media(max-width:380px){.tagline{font-size:28px}.scroll{padding-left:13px;padding-right:13px}.tripcard{border-radius:19px}}


/* PWA/mobile polish from ui-ux-pro-max pass: tactile, readable, offline-first */
:focus-visible{outline:3px solid rgba(255,194,96,.72);outline-offset:3px}
button,.chip,.tripcard,.it,.pk,.raterow{touch-action:manipulation;min-height:44px}
.backbtn,.xbtn,.iconbtn,.swapbtn{min-width:44px;min-height:44px}
.statusline{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--text-3);font-family:var(--mono);font-size:9px;letter-spacing:.8px;text-transform:uppercase}
.statusline .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 14px rgba(84,224,164,.45)}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
@media(display-mode:standalone){.apphead{padding-top:max(15px,env(safe-area-inset-top))}.fab.home{bottom:calc(24px + env(safe-area-inset-bottom))}}
