@import "https://fonts.googleapis.com/css2?family=Fredoka:wght@500;600;700&family=Space+Grotesk:wght@400;500;700&display=swap";html{scroll-behavior:smooth}#root{min-height:100vh}:root{color:#1b2333;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--paper:#fffaf0;--ink:#1b2333;--muted:#667085;--line:#e8ddc7;--orange:coral;--green:#27c499;--blue:#4d96ff;--shadow:0 24px 70px #1f293724;background:#f4efe4;font-family:Space Grotesk,system-ui,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(circle at 20% 0,#fff2c2 0,#0000 34%),linear-gradient(145deg,#f5ead7,#edf6ef);min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer;transition:transform .14s,box-shadow .14s,background-color .14s,filter .14s}button:active,.maps-button:active,.navigate-day:active,.mini-map-link:active{filter:brightness(.96);transform:scale(.97)}a{color:inherit;text-decoration:none}h1,h2,h3{margin:0;font-family:Fredoka,system-ui,sans-serif;line-height:1.02}h1{font-size:clamp(2rem,6vw,4.5rem)}h2{font-size:clamp(1.4rem,4vw,2rem)}h3{font-size:1.1rem}p{color:var(--muted);margin:0}.eyebrow{color:var(--orange);text-transform:uppercase;letter-spacing:.11em;font-size:.76rem;font-weight:800}.hint{color:#7b6c58;font-size:.88rem}.meta{color:#8a7358;font-size:.78rem;font-weight:700}.primary{color:#fffaf0;background:#1b2333;border:0;border-radius:999px;padding:.8rem 1rem;font-weight:800;box-shadow:0 10px 24px #1b23332e}.primary:hover{transform:translateY(-2px);box-shadow:0 14px 28px #1b233338}.primary.wide{width:100%;margin-top:1rem}.pill{color:#257c61;background:#eaf6ef;border-radius:999px;padding:.45rem .7rem;font-size:.78rem;font-weight:800}.gate{place-items:center;min-height:100vh;padding:1rem;display:grid}.gate-card{width:min(920px,100%);box-shadow:var(--shadow);background:#fffaf0eb;border:3px solid #1b2333;border-radius:36px;padding:clamp(1.25rem,4vw,3rem)}.gate-copy{max-width:560px;margin:.7rem 0 1.4rem}.avatar-grid{grid-template-columns:repeat(6,minmax(104px,1fr));gap:1rem;display:grid}.avatar-card{background:#fff6df;border:3px solid #1b2333;border-radius:26px;place-items:center;gap:.35rem;min-height:160px;font-weight:900;transition:transform .2s,box-shadow .2s;display:grid;box-shadow:0 8px #1b2333}.avatar-card:hover{transform:translateY(-4px);box-shadow:0 12px #1b2333}.avatar{flex:none;place-items:center;display:inline-grid}.avatar svg{filter:drop-shadow(0 5px #1b23331a);width:100%;height:100%}.avatar-small{width:42px;height:42px}.avatar-normal{width:76px;height:76px}.avatar-large{width:104px;height:104px}.app-shell{width:min(1220px,100%);min-height:100vh;margin:0 auto;padding:1rem 1rem 6rem}.topbar{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.profile-button{background:#fffaf0;border:3px solid #1b2333;border-radius:999px;align-items:center;gap:.5rem;padding:.35rem .75rem .35rem .35rem;font-weight:900;display:flex}.screen{gap:1rem;animation:.22s appear;display:grid}@keyframes appear{0%{opacity:0;transform:translateY(8px)}}.driver-strip{color:#fffaf0;background:#1b2333;border-radius:28px;align-items:center;gap:.75rem;padding:.75rem;display:flex}.driver-strip select{color:#1b2333;background:#fffaf0;border:0;border-radius:999px;margin-left:auto;padding:.55rem .7rem;font-weight:800}.driver-stack{display:flex}.driver-stack .avatar{margin-right:-12px}.map-card{height:min(52vh,430px);min-height:330px;box-shadow:var(--shadow);background:#cce8db;border:3px solid #1b2333;border-radius:34px;position:relative;overflow:hidden}.map-bg{opacity:.95;background:radial-gradient(circle at 24% 62%,#b9d8c8 0 12%,#0000 13%),radial-gradient(circle at 70% 20%,#b7d9eb 0 15%,#0000 16%),linear-gradient(135deg,#d8efdf 0 40%,#bdd9ef 41% 55%,#f6dcaf 56%);position:absolute;inset:0}.map-bg:after{content:"";background-image:linear-gradient(30deg,#ffffff40 1px,#0000 1px),linear-gradient(120deg,#ffffff40 1px,#0000 1px);background-size:58px 58px;position:absolute;inset:0}.route-svg{width:100%;height:100%;position:absolute;inset:0}.pin{background:var(--orange);color:#1b2333;border:3px solid #1b2333;border-radius:999px 999px 999px 8px;place-items:center;width:42px;height:42px;font-weight:900;display:grid;position:absolute;transform:rotate(-45deg);box-shadow:0 8px #1b233326}.pin:after{content:attr(class);display:none}.pin{color:#0000}.pin:before{content:attr(data-label)}.pin-one{bottom:17%;left:8%}.pin-two{top:30%;left:45%}.pin-three{top:16%;right:9%}.pin-four{bottom:30%;right:17%}.pin-one:before{content:"1";color:#1b2333;transform:rotate(45deg)}.pin-two:before{content:"2";color:#1b2333;transform:rotate(45deg)}.pin-three:before{content:"3";color:#1b2333;transform:rotate(45deg)}.pin-four:before{content:"?";color:#1b2333;transform:rotate(45deg)}.pin.ghost{background:#fffaf0;border-style:dashed}.drive-badge{background:#fffaf0;border:3px solid #1b2333;border-radius:999px;padding:.35rem .65rem;font-weight:900;position:absolute;box-shadow:0 6px #1b23331f}.badge-one{top:41%;left:24%}.badge-two{top:44%;right:27%}.navigate-day{color:#fffaf0;background:#1b2333;border-radius:999px;place-items:center;padding:.95rem;font-weight:900;display:grid;position:absolute;bottom:1rem;left:1rem;right:1rem}.route-photo-card{background:linear-gradient(145deg,#fffaf0,#eaf6ef);gap:1rem;height:auto;min-height:0;padding:1rem;display:grid}.route-photo-card .navigate-day{position:static;bottom:auto;left:auto;right:auto}.route-photo-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.photo-route-line{gap:.7rem;display:grid}.photo-route-step{grid-template-columns:1fr auto;align-items:center;gap:.6rem;display:grid}.photo-stop-link{background:#fff;border:3px solid #1b2333;border-radius:24px;min-height:116px;display:block;position:relative;overflow:hidden;box-shadow:0 8px #1b23331f}.photo-stop-link:hover{transform:translateY(-2px);box-shadow:0 11px #1b233324}.photo-stop-link img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.photo-stop-link:after{content:"";background:linear-gradient(90deg,#1b2333d1,#1b23331a);position:absolute;inset:0}.photo-stop-number{z-index:1;background:var(--orange);color:#1b2333;border:3px solid #1b2333;border-radius:999px;place-items:center;width:40px;height:40px;font-weight:900;display:grid;position:absolute;top:.7rem;left:.7rem}.photo-stop-text{z-index:1;color:#fffaf0;gap:.15rem;display:grid;position:absolute;bottom:.8rem;left:.85rem;right:.85rem}.photo-stop-text strong{font-family:Fredoka;font-size:1.25rem;line-height:1}.photo-stop-text small{color:#fffaf0d1;font-weight:800}.photo-drive-pill{text-align:center;background:#fffaf0;border:3px solid #1b2333;border-radius:999px;gap:.05rem;min-width:82px;padding:.55rem .7rem;display:grid;box-shadow:0 6px #1b23331a}.photo-drive-pill span{font-weight:900}.photo-drive-pill small{color:var(--muted);font-size:.72rem;font-weight:800}.ghost-stop{border-style:dashed;width:100%;min-height:96px}.ghost-stop:after{background:linear-gradient(90deg,#fffaf0e6,#fffaf0b8)}.ghost-question{z-index:1;color:#1b2333;background:#fffaf0;border:3px dashed #1b2333;border-radius:999px;place-items:center;width:46px;height:46px;font-weight:900;display:grid;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.ghost-stop .photo-stop-text{color:#1b2333;top:50%;bottom:auto;left:4.6rem;transform:translateY(-50%)}.ghost-stop .photo-stop-text small{color:var(--muted)}.section-heading{justify-content:space-between;align-items:center;gap:1rem;display:flex}.timeline-list,.card-list,.activity-list{gap:.85rem;display:grid}.stop-card,.expense-card,.person-card,.stat,.settle-card,.activity-item{background:#fffaf0eb;border:3px solid #1b2333;border-radius:26px;transition:transform .16s,box-shadow .16s;box-shadow:0 8px #1b23331c}.stop-card:hover,.expense-card:hover,.person-card:hover{transform:translateY(-2px);box-shadow:0 11px #1b233321}.stop-card{grid-template-columns:124px 1fr;gap:1rem;padding:.75rem;display:grid}.stop-card.suggested{background:#fff7e6;border-style:dashed}.stop-card>img{object-fit:cover;border:2px solid #1b2333;border-radius:18px;width:100%;height:100%;min-height:132px}.stop-content{gap:.6rem;display:grid}.stop-title-row,.expense-top{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.maps-button,.mini-map-link{color:#18624b;background:#eaf6ef;border:2px solid #1b2333;border-radius:999px;width:fit-content;padding:.45rem .65rem;font-weight:900;display:inline-flex}.chips,.member-chips{flex-wrap:wrap;gap:.45rem;display:flex}.chips span,.member-chips button{background:#fff;border:2px solid #1b2333;border-radius:999px;padding:.38rem .58rem;font-size:.78rem;font-weight:800}.member-chips button.selected{background:#dff7eb;box-shadow:inset 0 0 0 3px #27c4992e}.leg-mini{color:#5a4a35;background:#f1eadb;border-radius:16px;padding:.55rem .65rem;font-weight:800}.vote-box{gap:.45rem;display:grid}.vote-meter{background:#fff;border:2px solid #1b2333;border-radius:999px;height:12px;overflow:hidden}.vote-meter span{background:linear-gradient(90deg,#ffd166,#27c499);height:100%;display:block}.vote-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.vote-row button{background:#fff;border:2px solid #1b2333;border-radius:999px;padding:.4rem .6rem;font-weight:900}.stats-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.stat{gap:.35rem;padding:1rem;display:grid}.stat span{color:var(--muted);font-size:.8rem;font-weight:800}.stat strong{font-family:Fredoka;font-size:1.45rem}.expense-card{gap:.7rem;padding:1rem;display:grid}.settle-grid,.people-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.settle-card{grid-template-columns:auto 1fr;align-items:center;gap:.5rem;padding:.85rem;display:grid}.settle-card strong{grid-column:1/-1}.positive{color:#15845f}.negative{color:#d04848}.person-card{text-align:center;place-items:center;gap:.4rem;padding:1rem;display:grid}.person-card.me{background:#fff0d8}.person-card button{background:#fff;border:2px solid #1b2333;border-radius:999px;padding:.45rem .7rem;font-weight:900}.activity-item{justify-content:space-between;gap:1rem;padding:.85rem 1rem;display:flex}.activity-item time{color:var(--muted);white-space:nowrap;font-size:.8rem}.bottom-nav{z-index:20;width:min(680px,100% - 1.2rem);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1b2333eb;border:3px solid #1b2333;border-radius:999px;grid-template-columns:repeat(4,1fr);gap:.45rem;padding:.45rem;display:grid;position:fixed;bottom:.75rem;left:50%;transform:translate(-50%)}.bottom-nav button{color:#fffaf0;background:0 0;border:0;border-radius:999px;padding:.75rem .4rem;font-weight:900}.bottom-nav button.active{color:#1b2333;background:#fffaf0}.sheet-backdrop{z-index:40;background:#1b233359;align-items:end;display:grid;position:fixed;inset:0}.sheet{width:min(720px,100%);max-height:92vh;box-shadow:var(--shadow);background:#fffaf0;border:3px solid #1b2333;border-bottom:0;border-radius:34px 34px 0 0;margin:0 auto;padding:1.25rem;animation:.2s sheet-pop;position:relative;overflow:auto}@keyframes sheet-pop{0%{opacity:.8;transform:translateY(28px)}}.close{background:#fff;border:2px solid #1b2333;border-radius:999px;width:40px;height:40px;font-size:1.4rem;font-weight:900;position:absolute;top:1rem;right:1rem}.import-options{gap:.65rem;margin-top:1rem;display:grid}.import-options button{text-align:left;background:#fff;border:3px solid #1b2333;border-radius:22px;gap:.25rem;padding:1rem;display:grid;box-shadow:0 6px #1b23331a}.import-options span{color:var(--muted)}@media (width>=900px){.route-screen{grid-template-columns:1.1fr .9fr;align-items:start}.driver-strip,.map-card{grid-column:1}.section-heading,.timeline-list,.route-screen>.hint{grid-column:2}.map-card{height:calc(100vh - 168px);position:sticky;top:1rem}.route-photo-card{height:auto;max-height:none;overflow:visible}.bottom-nav{margin:2rem auto 0;position:static;bottom:auto;left:auto;transform:none}}@media (width<=760px){.app-shell{padding-inline:.75rem}.avatar-grid,.stats-grid,.settle-grid,.people-grid{grid-template-columns:repeat(2,1fr)}.gate-card{border-radius:28px}.avatar-card{min-height:142px}.topbar h1{font-size:1.7rem}.profile-button span{display:none}.map-card{border-radius:28px;min-height:290px}.stop-card{grid-template-columns:92px 1fr;gap:.65rem}.stop-card>img{min-height:116px}.stop-title-row,.expense-top,.section-heading{align-items:stretch}.section-heading{flex-direction:column}.primary{width:100%}.stats-grid{gap:.55rem}.stat{padding:.75rem}.stat strong{font-size:1.05rem}}@media (width<=420px){.avatar-grid{grid-template-columns:1fr 1fr}.stop-card{grid-template-columns:1fr}.stop-card>img{height:160px}.bottom-nav button{font-size:.8rem}}.source-tabs{grid-template-columns:repeat(3,1fr);gap:.5rem;margin:1rem 0;display:grid}.source-tabs button{background:#fff;border:2px solid #1b2333;border-radius:999px;padding:.65rem .5rem;font-weight:900}.source-tabs button.active{color:#fffaf0;background:#1b2333}.suggest-form{gap:.8rem;margin-top:.5rem;display:grid}.suggest-form label{color:#4b5563;gap:.35rem;font-size:.85rem;font-weight:900;display:grid}.suggest-form input{color:#1b2333;background:#fff;border:2px solid #1b2333;border-radius:16px;width:100%;padding:.82rem .9rem}.suggest-form input:disabled{color:#6b7280;background:#f3eee3}.inline-field{grid-template-columns:1fr auto;gap:.45rem;display:grid}.inline-field button{background:#ffd166;border:2px solid #1b2333;border-radius:16px;padding:0 .8rem;font-weight:900}.form-grid{grid-template-columns:1fr 1fr;gap:.65rem;display:grid}.suggest-preview{object-fit:cover;border:2px solid #1b2333;border-radius:18px;width:100%;max-height:180px}.form-error{color:#c2410c;font-weight:900}.suggest-hint{background:#fff7dc;border:2px dashed #1b2333;border-radius:18px;gap:.2rem;padding:.8rem;display:grid}.suggest-hint strong{color:#1b2333}.suggest-hint span{color:#6b7280;font-size:.86rem}.suggest-page{max-width:720px;margin:0 auto;padding-bottom:1rem}.suggest-panel{background:#fffaf0;border:3px solid #1b2333;border-radius:28px;padding:1.1rem;box-shadow:0 18px #1b23331f}.back-link{margin-bottom:.9rem}.ghost{color:#1b2333;background:#fff;border:2px solid #1b2333;border-radius:999px;padding:.7rem 1rem;font-weight:900}.google-search-block{gap:.65rem;display:grid}.place-results{gap:.5rem;display:grid}.place-results button{text-align:left;background:#fff;border:2px solid #1b2333;border-radius:18px;gap:.2rem;padding:.75rem .85rem;display:grid;box-shadow:0 5px #1b23331a}.place-results button:hover{background:#fff4db;transform:translateY(-1px)}.place-results span{color:#6b7280;font-size:.86rem}.selected-place{background:#eaf6ef;border:2px solid #1b2333;border-radius:18px;gap:.2rem;padding:.75rem .85rem;display:grid}.selected-place span{color:#18624b;font-weight:900}.selected-place small{color:#4b5563}.sheet-form{gap:.75rem;margin-top:1rem;display:grid}.sheet-form label{color:#4b5563;gap:.35rem;font-size:.85rem;font-weight:900;display:grid}.sheet-form input,.sheet-form select{color:#1b2333;background:#fff;border:2px solid #1b2333;border-radius:16px;width:100%;padding:.82rem .9rem}.location-card{background:#fff7dc;border:2px dashed #1b2333;border-radius:20px;gap:.45rem;padding:.75rem;display:grid}.secondary-action{background:#ffd166;border:2px solid #1b2333;border-radius:999px;padding:.75rem .9rem;font-weight:900}.secondary-action:disabled{opacity:.65;cursor:progress}.receipt-capture{text-align:center;background:#fff7dc;border:3px dashed #1b2333;border-radius:22px;place-items:center;padding:.95rem}.receipt-capture input{background:0 0;border:0;padding:.4rem 0 0}.receipt-preview,.receipt-thumb{object-fit:cover;background:#fff;border:2px solid #1b2333;border-radius:18px;width:100%}.receipt-preview{max-height:220px}.receipt-thumb{max-height:150px}
